zabbix 批量添加主机

zabbix 批量添加主机

1.1::通过本教程起到抛砖引玉效果,希望各位朋友受益良多。

1.2::如您有任何问题请联系作者,QQ1284524409。

1.3::以下提供的任何软件仅供学习交流使用。


 

#!/usr/bin/python
# coding:utf-8
  
import json
import urllib2
from urllib2 import URLError
import sys, argparse
import xlrd

defaultencoding = 'utf-8'
if sys.getdefaultencoding() != defaultencoding:
    reload(sys)
    sys.setdefaultencoding(defaultencoding)
  
class zabbix_api:
    def __init__(self):
        self.url = 'http://127.0.0.1/zabbix/api_jsonrpc.php'  # 修改URL
        self.header = {"Content-Type":"application/json"}
        self.user_login()

    def user_login(self):
        data = json.dumps({
                           "jsonrpc": "2.0",
                           "method": "user.login",
                           "params": {
                                      "user": "Admin",  # web页面登录用户名
                                      "password": "zabbix"  # web页面登录密码
                                      },
                           "id": 0
                           })
        request = urllib2.Request(self.url, data, self.header)
        try:
            result = urllib2.urlopen(request, timeout = 2)
        except URLError as e:
            print u"\033[041m地址请求失败请检查!\033[0m \n\033[041m%s!\033[0m" % e
            sys.exit(1)
        else:
            response = json.loads(result.read())
            result.close()
            if response.get('result','') != '':
                self.authID = response['result']
            elif response.get('error','') != '':
                print u"\033[041m用户认证失败请检查!\033[0m \n\033[041m%s\033[0m" % (response['error']['data'])
                sys.exit(1)
    #![01_创建模板]
    def template_get(self, templateName):
        data = json.dumps({
                            "jsonrpc":"2.0",
                            "method":"template.get",
                            "params":{
                                    "output": "extend",
                                    "filter": {
                                                "host": templateName
                                            }
                                    },
                            "auth":self.authID,
                            "id":1,
                        })
        request = urllib2.Request(self.url, data, self.header)     
        result = urllib2.urlopen(request)
        response = json.loads(result.read())
        result.close()
        if response.get('result','') != []:
            return response['result'][0]['templateid']
        else:
            return response['result']
                    
    def template_create(self, templateName):
        default_id = {}
        default_id['groupid'] = self.hostGroup_get('000_LocalTemplates')
        if default_id['groupid'] == []:
            self.hostGroup_create('000_LocalTemplates')
            default_id['groupid'] = self.hostGroup_get('000_LocalTemplates')
        name_list_1 = []
        for n_1 in templateName.split('//'):
            name_1 = {}
            name_1['name'] = n_1
            name_list_1.append(name_1)
        name_list_2 = []
        for n_2 in range(len(name_list_1)):
            name_2 = {}
            id_2 = {}
            name_2['name'] = name_list_1[n_2]['name']
            id_2['templateid'] = self.template_get(name_list_1[n_2]['name'])
            if id_2['templateid'] != []:
                print u"创建模板 : \033[041m%s\033[0m 失败!,模板重复创建" % name_list_1[n_2]['name']
                continue
            name_list_2.append(name_2)
        for n_3 in range(len(name_list_2)):
            data = json.dumps({
                                "jsonrpc": "2.0",
                                "method": "template.create",
                                "params": {
                                            "host": name_list_2[n_3]['name'],
                                            "groups": {
                                                        "groupid": default_id['groupid']
                                                    },
                                        },
                                "auth": self.authID,
                                "id": 1
                            })
            request = urllib2.Request(self.url, data, self.header)
            result = urllib2.urlopen(request)
            response = json.loads(result.read())
            result.close()
            if response.get('result','') != '':
                print u"创建模板 : \033[042m%s\033[0m 成功!,模板ID为 : \033[042m%s\033[0m" % (name_list_2[n_3]['name'], ",".join(response['result']['templateids']))
            elif response.get('error','') != '':
                print u"创建模板 : \033[041m%s\033[0m 失败!\n\033[041m%s\033[0m" % (name_list_2[n_3]['name'], response['error']['data'])

    def template_delete(self, templateName):
        name_list_1 = []
        for n_1 in templateName.split('//'):
            name_1 = {}
            name_1['name'] = n_1
            name_list_1.append(name_1)
        name_list_2 = []
        id_list_2 = []
        for n_2 in range(len(name_list_1)):
            name_2 = {}
            id_2 = {}
            name_2['name'] = name_list_1[n_2]['name']
            id_2['templateids'] = self.template_get(name_list_1[n_2]['name'])
            if id_2['templateids'] == []:
                print u"删除模板 : \033[041m%s\033[0m 失败!,模板不存在!" % name_list_1[n_2]['name']
                continue
            name_list_2.append(name_2)
            id_list_2.append(id_2)
        for n_3 in range(len(name_list_2)):
            data = json.dumps({
                                "jsonrpc": "2.0",
                                "method": "template.delete",
                                "params": [
                                            id_list_2[n_3]['templateids']
                                        ],
                                "auth": self.authID,
                                "id": 1
                            })
            request = urllib2.Request(self.url, data, self.header)
            result = urllib2.urlopen(request)
            response = json.loads(result.read())
            result.close()
            if response.get('result','') != '':
                print u"删除模板 : \033[042m%s\033[0m 成功!,模板ID为 : \033[042m%s\033[0m" % (name_list_2[n_3]['name'], ",".join(response['result']['templateids']))
            elif response.get('error','') != '':
                print u"删除模板 : \033[041m%s\033[0m 失败!\n\033[041m%s\033[0m" % (name_list_2[n_3]['name'], response['error']['data'])
    #![02_为模板创建应用集]
    def application_get(self, templateName, applicationName):
        data = json.dumps({
                            "jsonrpc":"2.0",
                            "method":"application.get",
                            "params":{
                                    "output": "extend",
                                    "hostids": self.template_get(templateName),
                                    "filter":{
                                            "name": applicationName
                                        },
                                    },
                            "auth":self.authID,
                            "id":1,
                        })
        request = urllib2.Request(self.url, data, self.header)     
        result = urllib2.urlopen(request)
        response = json.loads(result.read())
        result.close()
        if response.get('result','') != []:
            return response['result'][0]['applicationid']
        else:
            return response['result']

    def application_create(self, templateName, applicationName):
        name_list_1 = []
        for n_1 in templateName.split('//'):
            name_1 = {}
            name_1['name'] = n_1
            name_list_1.append(name_1)
        name_list_2 = []
        for n_2 in applicationName.split('//'):
            name_2 = {}
            name_2['name'] = n_2
            name_list_2.append(name_2)
        if len(name_list_1) != len(name_list_2):
            print u"为模板删除应用集失败!,\033[041m输入的参数存在空值\033[0m"
            sys.exit(1)
        name_list_3_1 = []
        name_list_3_2 = []
        id_list_3 = []
        for n_3 in range(len(name_list_1)):
            name_3_1 = {}
            name_3_2 = {}
            id_3 = {}
            name_3_1['name'] = name_list_1[n_3]['name']
            name_3_2['name'] = name_list_2[n_3]['name']
            id_3['templateid'] = self.template_get(name_list_1[n_3]['name'])
            if id_3['templateid'] == []:
                print u"为模板 : \033[041m%s\033[0m 创建应用集失败!,\033[041m模板不存在\033[0m" % name_list_1[n_3]['name']
                continue
            name_list_3_1.append(name_3_1)
            name_list_3_2.append(name_3_2)
            id_list_3.append(id_3)
        name_list_4_1 = []
        name_list_4_2 = []
        id_list_4_1 = []
        id_list_4_2 = []
        for n_4 in range(len(name_list_3_1)):
            name_4_1 = {}
            name_4_2 = {}
            id_4_1 = {}
            id_4_2 = {}
            name_4_1['name'] = name_list_3_1[n_4]['name']
            name_4_2['name'] = name_list_3_2[n_4]['name']
            id_4_1['templateid'] = id_list_3[n_4]['templateid']
            id_4_2['applicationid'] = self.application_get(name_list_3_1[n_4]['name'], name_list_3_2[n_4]['name'])
            if id_4_2['applicationid'] != []:
                print u"为模板 : \033[041m%s\033[0m 创建应用集 : \033[041m%s\033[0m 失败!,\033[041m应用集已存在!\033[0m" % \
                (name_list_3_1[n_4]['name'], name_list_3_2[n_4]['name'])
                continue
            name_list_4_1.append(name_4_1)
            name_list_4_2.append(name_4_2)
            id_list_4_1.append(id_4_1)
            id_list_4_2.append(id_4_2)
        for n_5 in range(len(name_list_4_1)):
            data = json.dumps({
                                "jsonrpc": "2.0",
                                "method": "application.create",
                                "params": {
                                            "name": name_list_4_2[n_5]['name'],
                                            "hostid": id_list_4_1[n_5]['templateid'],
                                        },
                                "auth": self.authID,
                                "id": 1
                            })
            request = urllib2.Request(self.url, data, self.header)
            result = urllib2.urlopen(request)
            response = json.loads(result.read())
            result.close()
            if response.get('result','') != '':
                print u"为模板 : \033[042m%s\033[0m 创建应用集 : \033[042m%s\033[0m 成功!,并且应用集ID为 : \033[042m%s\033[0m" % \
                (name_list_4_1[n_5]['name'],name_list_4_2[n_5]['name'], ",".join(response['result']['applicationids']))
            elif response.get('error','') != '':
                print u"为模板 : \033[041m%s\033[0m 创建应用集 : \033[041m%s\033[0m 失败!\
                \n\033[041m%s\033[0m" % (name_list_4_1[n_5]['name'],name_list_4_2[n_5]['name'], response['error']['data'])

    def application_delete(self, templateName, applicationName):
        name_list_1 = []
        for n_1 in templateName.split('//'):
            name_1 = {}
            name_1['name'] = n_1
            name_list_1.append(name_1)
        name_list_2 = []
        for n_2 in applicationName.split('//'):
            name_2 = {}
            name_2['name'] = n_2
            name_list_2.append(name_2)
        if len(name_list_1) != len(name_list_2):
            print u"为模板删除应用集失败!,\033[041m输入的参数存在空值\033[0m"
            sys.exit(1)
        name_list_3_1 = []
        name_list_3_2 = []
        id_list_3 = []
        for n_3 in range(len(name_list_1)):
            name_3_1 = {}
            name_3_2 = {}
            id_3 = {}
            name_3_1['name'] = name_list_1[n_3]['name']
            name_3_2['name'] = name_list_2[n_3]['name']
            id_3['templateid'] = self.template_get(name_list_1[n_3]['name'])
            if id_3['templateid'] == []:
                print u"为模板 : \033[041m%s\033[0m 删除应用集失败!,模板不存在" % name_list_1[n_3]['name']
                continue
            name_list_3_1.append(name_3_1)
            name_list_3_2.append(name_3_2)
            id_list_3.append(id_3)
        name_list_4_1 = []
        name_list_4_2 = []
        id_list_4 = []
        for n_4 in range(len(name_list_3_1)):
            name_4_1 = {}
            name_4_2 = {}
            id_4 = {}
            name_4_1['name'] = name_list_3_1[n_4]['name']
            name_4_2['name'] = name_list_3_2[n_4]['name']
            id_4['applicationid'] = self.application_get(name_list_3_1[n_4]['name'], name_list_3_2[n_4]['name'])
            if id_4['applicationid'] == []:
                print u"为模板删除应用集失败!,\033[041m应用集不存在\033[0m !"
                continue
            name_list_4_1.append(name_4_1)
            name_list_4_2.append(name_4_2)
            id_list_4.append(id_4)
        for n_5 in range(len(name_list_4_1)):
            data = json.dumps({
                                "jsonrpc": "2.0",
                                "method": "application.delete",
                                "params": [
                                            id_list_4[n_5]['applicationid']
                                        ],
                                "auth": self.authID,
                                "id": 1
                            })
            request = urllib2.Request(self.url, data, self.header)
            result = urllib2.urlopen(request)
            response = json.loads(result.read())
            result.close()
            if response.get('result','') != '':
                print u"为模板 : \033[042m%s\033[0m 删除应用集 : \033[042m%s\033[0m 成功!,并且应用集ID为 : \033[042m%s\033[0m" % \
                (name_list_4_1[n_5]['name'],name_list_4_2[n_5]['name'], ",".join(response['result']['applicationids']))
            elif response.get('error','') != '':
                print u"为模板 : \033[041m%s\033[0m 删除应用集 : \033[041m%s\033[0m 失败!\
                \n\033[041m%s\033[0m" % (name_list_4_1[n_5]['name'],name_list_4_2[n_5]['name'], response['error']['data'])
    #![03_为模板创建监控项]
    def item_get(self, templateName, itemName):
        data = json.dumps({
                            "jsonrpc":"2.0",
                            "method":"item.get",
                            "params":{
                                    "output": "extend",
                                    "hostids": self.template_get(templateName),
                                    "filter":{
                                            "name": itemName
                                        },
                                    },
                            "auth":self.authID,
                            "id":1,
                        })
        request = urllib2.Request(self.url, data, self.header)     
        result = urllib2.urlopen(request)
        response = json.loads(result.read())
        result.close()
        if response.get('result','') != []:
            return response['result'][0]['itemid']
        else:
            return response['result']
              
    def item_create(self, templateName, itemApplication, itemName, itemKey, itemValueType, itemDely):
        name_list_1 = []
        for n_1 in templateName.split('//'):
            name_1 = {}
            name_1['name'] = n_1
            name_list_1.append(name_1)
        name_list_2 = []
        for n_2 in itemApplication.split('//'):
            name_2 = {}
            name_2['name'] = n_2
            name_list_2.append(name_2)
        name_list_3 = []
        for n_3 in itemName.split('//'):
            name_3 = {}
            name_3['name'] = n_3
            name_list_3.append(name_3)
        name_list_4 = []
        for n_4 in itemKey.split('//'):
            name_4 = {}
            name_4['name'] = n_4
            name_list_4.append(name_4)
        name_list_5 = []
        for n_5 in itemValueType.split('//'):
            name_5 = {}
            name_5['name'] = n_5
            name_list_5.append(name_5)
        name_list_6 = []
        for n_6 in itemDely.split('//'):
            name_6 = {}
            name_6['name'] = n_6
            name_list_6.append(name_6)  
        if len(name_list_1) != len(name_list_2) or \
        len(name_list_1) != len(name_list_3) or \
        len(name_list_1) != len(name_list_4) or \
        len(name_list_1) != len(name_list_5) or \
        len(name_list_1) != len(name_list_6):
            print u"为模板创建监控项失败!,\033[041m输入的参数存在空值\033[0m"
            sys.exit(1)
        name_list_7_1 = []
        name_list_7_2 = []
        name_list_7_3 = []
        name_list_7_4 = []
        name_list_7_5 = []
        name_list_7_6 = []
        id_list_7 = []
        for n_7 in range(len(name_list_1)):
            name_7_1 = {}
            name_7_2 = {}
            name_7_3 = {}
            name_7_4 = {}
            name_7_5 = {}
            name_7_6 = {}
            id_7 = {}
            name_7_1['name'] = name_list_1[n_7]['name']
            name_7_2['name'] = name_list_2[n_7]['name']
            name_7_3['name'] = name_list_3[n_7]['name']
            name_7_4['name'] = name_list_4[n_7]['name']
            name_7_5['name'] = name_list_5[n_7]['name']
            name_7_6['name'] = name_list_6[n_7]['name']
            id_7['templateid'] = self.template_get(name_list_1[n_7]['name'])
            if id_7['templateid'] == []:
                print u"为模板 : \033[041m%s\033[0m 创建监控项失败!,模板不存在" % name_list_1[n_7]['name']
                continue
            name_list_7_1.append(name_7_1)
            name_list_7_2.append(name_7_2)
            name_list_7_3.append(name_7_3)
            name_list_7_4.append(name_7_4)
            name_list_7_5.append(name_7_5)
            name_list_7_6.append(name_7_6)
            id_list_7.append(id_7)
        name_list_8_1 = []
        name_list_8_2 = []
        name_list_8_3 = []
        name_list_8_4 = []
        name_list_8_5 = []
        name_list_8_6 = []
        id_list_8_1 = []
        id_list_8_2 = []
        for n_8 in range(len(name_list_1)):
            name_8_1 = {}
            name_8_2 = {}
            name_8_3 = {}
            name_8_4 = {}
            name_8_5 = {}
            name_8_6 = {}
            id_8_1 = {}
            id_8_2 = {}
            name_8_1['name'] = name_list_7_1[n_8]['name']
            name_8_2['name'] = name_list_7_2[n_8]['name']
            name_8_3['name'] = name_list_7_3[n_8]['name']
            name_8_4['name'] = name_list_7_4[n_8]['name']
            name_8_5['name'] = name_list_7_5[n_8]['name']
            name_8_6['name'] = name_list_7_6[n_8]['name']
            id_8_1['templateid'] = id_list_7[n_8]['templateid']
            id_8_2['applicationid'] = self.application_get(name_list_7_1[n_8]['name'], name_list_7_2[n_8]['name'])
            if id_8_2['applicationid'] == []:
                print u"为监控项 : \033[041m%s\033[0m 附加应用集 : \033[041m%s\033[0m 失败!,应用集不存在" % \
                (name_list_7_3[n_8]['name'], name_list_7_2[n_8]['name'])
                continue
            name_list_8_1.append(name_8_1)
            name_list_8_2.append(name_8_2)
            name_list_8_3.append(name_8_3)
            name_list_8_4.append(name_8_4)
            name_list_8_5.append(name_8_5)
            name_list_8_6.append(name_8_6)
            id_list_8_1.append(id_8_1)
            id_list_8_2.append(id_8_2)
        name_list_9_1 = []
        name_list_9_2 = []
        name_list_9_3 = []
        name_list_9_4 = []
        name_list_9_5 = []
        name_list_9_6 = []
        id_list_9_1 = []
        id_list_9_2 = []
        for n_9 in range(len(name_list_1)):
            name_9_1 = {}
            name_9_2 = {}
            name_9_3 = {}
            name_9_4 = {}
            name_9_5 = {}
            name_9_6 = {}
            id_9_1 = {}
            id_9_2 = {}
            id_9_3 = {}
            name_9_1['name'] = name_list_8_1[n_9]['name']
            name_9_2['name'] = name_list_8_2[n_9]['name']
            name_9_3['name'] = name_list_8_3[n_9]['name']
            name_9_4['name'] = name_list_8_4[n_9]['name']
            name_9_5['name'] = name_list_8_5[n_9]['name']
            name_9_6['name'] = name_list_8_6[n_9]['name']
            id_9_1['templateid'] = id_list_8_1[n_9]['templateid']
            id_9_2['applicationid'] = id_list_8_2[n_9]['applicationid']
            id_9_3['itemid'] = self.item_get(name_list_8_1[n_9]['name'], name_list_8_3[n_9]['name'])
            if id_9_3['itemid'] != []:
                print u"为模板 : \033[041m%s\033[0m 创建监控项失败!,监控项 : \033[041m%s\033[0m 已存在,并且监控项ID为 : \033[041m%s\033[0m" % \
                    (name_list_8_1[n_9]['name'], name_list_8_3[n_9]['name'], id_9_3['itemid'])
                continue
            name_list_9_1.append(name_9_1)
            name_list_9_2.append(name_9_2)
            name_list_9_3.append(name_9_3)
            name_list_9_4.append(name_9_4)
            name_list_9_5.append(name_9_5)
            name_list_9_6.append(name_9_6)
            id_list_9_1.append(id_9_1)
            id_list_9_2.append(id_9_2)
        for n_10 in range(len(name_list_9_1)):
            data = json.dumps({
                                "jsonrpc": "2.0",
                                "method": "item.create",
                                "params": {
                                            "hostid": id_list_9_1[n_10]['templateid'],
                                            "applications": [id_list_9_2[n_10]['applicationid']],
                                            "name": name_list_9_3[n_10]['name'],
                                            "type": 7,
                                            "key_": name_list_9_4[n_10]['name'],
                                            "value_type": name_list_9_5[n_10]['name'],
                                            "delay": name_list_9_6[n_10]['name']
                                        },
                                "auth": self.authID,
                                "id": 1
                            })
            request = urllib2.Request(self.url, data, self.header)
            result = urllib2.urlopen(request)
            response = json.loads(result.read())
            result.close()
            if response.get('result','') != '':
                print u"为模板 : \033[042m%s\033[0m 创建监控项 : \033[042m%s\033[0m 成功!,并且监控项ID为 : \033[042m%s\033[0m" % \
                (name_list_9_1[n_10]['name'], name_list_9_3[n_10]['name'], ",".join(response['result']['itemids']))
            elif response.get('error','') != '':
                print u"为模板 : \033[041m%s\033[0m 创建监控项 : \033[041m%s\033[0m 失败!\
                \n\033[041m%s\033[0m" % (name_list_9_1[n_10]['name'], name_list_9_3[n_10]['name'], response['error']['data'])

    def item_delete(self, templateName, itemName):
        name_list_1 = []
        for n_1 in templateName.split('//'):
            name_1 = {}
            name_1['name'] = n_1
            name_list_1.append(name_1)
        name_list_2 = []
        for n_2 in itemName.split('//'):
            name_2 = {}
            name_2['name'] = n_2
            name_list_2.append(name_2)
        if len(name_list_1) != len(name_list_2):
            print u"为模板删除应用集失败!,\033[041m输入的参数存在空值\033[0m"
            sys.exit(1)
        name_list_3_1 = []
        name_list_3_2 = []
        id_list_3 = []
        for n_3 in range(len(name_list_1)):
            name_3_1 = {}
            name_3_2 = {}
            id_3 = {}
            name_3_1['name'] = name_list_1[n_3]['name']
            name_3_2['name'] = name_list_2[n_3]['name']
            id_3['templateid'] = self.template_get(name_list_1[n_3]['name'])
            if id_3['templateid'] == []:
                print u"为模板 : \033[041m%s\033[0m 删除监控项失败!,模板不存在" % name_list_1[n_3]['name']
                continue
            name_list_3_1.append(name_3_1)
            name_list_3_2.append(name_3_2)
            id_list_3.append(id_3)
        name_list_4_1 = []
        name_list_4_2 = []
        id_list_4 = []
        for n_4 in range(len(name_list_3_1)):
            name_4_1 = {}
            name_4_2 = {}
            id_4 = {}
            name_4_1['name'] = name_list_3_1[n_4]['name']
            name_4_2['name'] = name_list_3_2[n_4]['name']
            id_4['itemid'] = self.item_get(name_list_3_1[n_4]['name'], name_list_3_2[n_4]['name'])
            if id_4['itemid'] == []:
                print u"为模板 : \033[041m%s\033[0m 删除监控项 : \033[041m%s\033[0m 失败!,\033[041m监控项不存在\033[0m !" %\
                (name_list_4_1[n_4]('name'), name_list_4_2[n_4]('name'))
                continue
            name_list_4_1.append(name_4_1)
            name_list_4_2.append(name_4_2)
            id_list_4.append(id_4)
        for n_5 in range(len(name_list_4_1)):
            data = json.dumps({
                                "jsonrpc": "2.0",
                                "method": "item.delete",
                                "params": [
                                            id_list_4[n_5]['itemid']
                                        ],
                                "auth": self.authID,
                                "id": 1
                            })
            request = urllib2.Request(self.url, data, self.header)
            result = urllib2.urlopen(request)
            response = json.loads(result.read())
            result.close()
            if response.get('result','') != '':
                print u"为模板 : \033[042m%s\033[0m 删除监控项 : \033[042m%s\033[0m 成功!,并且应监控项ID为 : \033[042m%s\033[0m" % \
                (name_list_4_1[n_5]['name'],name_list_4_2[n_5]['name'], ",".join(response['result']['itemids']))
            elif response.get('error','') != '':
                print u"为模板 : \033[041m%s\033[0m 删除监控项 : \033[041m%s\033[0m 失败!\
                \n\033[041m%s\033[0m" % (name_list_4_1[n_5]['name'],name_list_4_2[n_5]['name'], response['error']['data'])
    #![04_为模板创建触发器]
    def trigger_get(self, templateName, descriptionName):
        data = json.dumps({
                            "jsonrpc":"2.0",
                            "method":"trigger.get",
                            "params":{
                                    "output": "extend",
                                    "templateids": self.template_get(templateName),
                                    "filter":{
                                            "description": descriptionName
                                        },
                                    },
                            "auth":self.authID,
                            "id":1,
                        })
        request = urllib2.Request(self.url, data, self.header)     
        result = urllib2.urlopen(request)
        response = json.loads(result.read())
        result.close()
        if response.get('result','') != []:
            return response['result'][0]['triggerid']
        else:
            return response['result']

    def trigger_create(self, templateName, itemName, descriptionName, expressionName):
        name_list_1 = []
        for n_1 in templateName.split('//'):
            name_1 = {}
            name_1['name'] = n_1
            name_list_1.append(name_1)
        name_list_2 = []
        for n_2 in itemName.split('//'):
            name_2 = {}
            name_2['name'] = n_2
            name_list_2.append(name_2)
        name_list_3 = []
        for n_3 in descriptionName.split('//'):
            name_3 = {}
            name_3['name'] = n_3
            name_list_3.append(name_3)
        name_list_4 = []
        for n_4 in expressionName.split('//'):
            name_4 = {}
            name_4['name'] = n_4
            name_list_4.append(name_4)
        if len(name_list_1) != len(name_list_2) or \
        len(name_list_1) != len(name_list_3) or \
        len(name_list_1) != len(name_list_4):
            print u"为模板创建触发器失败!,\033[041m输入的参数存在空值\033[0m"
            sys.exit(1)
        name_list_5_1 = []
        name_list_5_2 = []
        name_list_5_3 = []
        name_list_5_4 = []
        for n_5 in range(len(name_list_1)):
            name_5_1 = {}
            name_5_2 = {}
            name_5_3 = {}
            name_5_4 = {}
            id_5 = {}
            name_5_1['name'] = name_list_1[n_5]['name']
            name_5_2['name'] = name_list_2[n_5]['name']
            name_5_3['name'] = name_list_3[n_5]['name']
            name_5_4['name'] = name_list_4[n_5]['name']
            id_5['templateid'] = self.template_get(name_list_1[n_5]['name'])
            if id_5['templateid'] == []:
                print u"为模板 : \033[041m%s\033[0m 的监控项创建触发器失败!,模板不存在"  % name_list_1[n_5]['name']
                continue
            name_list_5_1.append(name_5_1)
            name_list_5_2.append(name_5_2)
            name_list_5_3.append(name_5_3)
            name_list_5_3.append(name_5_3)
            name_list_5_4.append(name_5_4)
        name_list_6_1 = []
        name_list_6_2 = []
        name_list_6_3 = []
        name_list_6_4 = []
        for n_6 in range(len(name_list_5_1)):
            name_6_1 = {}
            name_6_2 = {}
            name_6_3 = {}
            name_6_4 = {}
            id_6 = {}
            name_6_1['name'] = name_list_5_1[n_6]['name']
            name_6_2['name'] = name_list_5_2[n_6]['name']
            name_6_3['name'] = name_list_5_3[n_6]['name']
            name_6_4['name'] = name_list_5_4[n_6]['name']
            id_6['itemid'] = self.item_get(name_list_5_1[n_6]['name'], name_list_5_2[n_6]['name'])
            if id_6['itemid'] == []:
                print u"为模板 : \033[041m%s\033[0m 的监控项 : \033[041m%s\033[0m 创建触发器失败!,监控项不存在" % \
                (name_list_5_1[n_6]['name'], name_list_5_2[n_6]['name'])
                continue
            name_list_6_1.append(name_6_1)
            name_list_6_2.append(name_6_2)
            name_list_6_3.append(name_6_3)
            name_list_6_4.append(name_6_4)
        name_list_7_1 = []
        name_list_7_2 = []
        name_list_7_3 = []
        name_list_7_4 = []
        for n_7 in range(len(name_list_5_1)):
            name_7_1 = {}
            name_7_2 = {}
            name_7_3 = {}
            name_7_4 = {}
            id_7 = {}
            name_7_1['name'] = name_list_5_1[n_7]['name']
            name_7_2['name'] = name_list_5_2[n_7]['name']
            name_7_3['name'] = name_list_5_3[n_7]['name']
            name_7_4['name'] = name_list_5_4[n_7]['name']
            id_7['description'] = self.trigger_get(name_list_5_1[n_7]['name'], name_list_5_3[n_7]['name'])
            if id_7['description'] != []:
                print u"为模板 : \033[041m%s\033[0m 的监控项 : \033[041m%s\033[0m 创建触发器失败!,触发器 : \033[041m%s\033[0m 已存在,并且触发器ID为 : \033[041m%s\033[0m" % \
                (name_list_5_1[n_7]['name'], name_list_5_2[n_7]['name'], name_list_5_3[n_7]['name'], id_7['description'])
                continue
            name_list_7_1.append(name_7_1)
            name_list_7_2.append(name_7_2)
            name_list_7_3.append(name_7_3)
            name_list_7_4.append(name_7_4)
        for n_8 in range(len(name_list_7_1)):
            data = json.dumps({
                                "jsonrpc": "2.0",
                                "method": "trigger.create",
                                "params": {
                                            "description": name_list_7_3[n_8]['name'],
                                            "expression": name_list_7_4[n_8]['name'],
                                            "priority": 5,
                                            "manual_close": 1
                                        },
                                "auth": self.authID,
                                "id": 1
                            })
            request = urllib2.Request(self.url, data, self.header)
            result = urllib2.urlopen(request)
            response = json.loads(result.read())
            result.close()
            if response.get('result','') != '':
                print u"为模板 : \033[042m%s\033[0m 的监控项 : \033[042m%s\033[0m 创建触发器 : \033[042m%s\033[0m 成功!,并且触发器ID为 : \033[042m%s\033[0m" % \
                (name_list_7_1[n_8]['name'], name_list_7_2[n_8]['name'], name_list_7_3[n_8]['name'], ",".join(response['result']['triggerids']))
            elif response.get('error','') != '':
                print u"为模板 : \033[041m%s\033[0m 的监控项 : \033[041m%s\033[0m 创建触发器 : \033[041m%s\033[0m 失败!\
                \n\033[041m%s\033[0m" % (name_list_7_1[n_8]['name'], name_list_7_2[n_8]['name'], name_list_7_3[n_8]['name'], response['error']['data'])
                
    def trigger_delete(self, templateName, descriptionName):
        name_list_1 = []
        for n_1 in templateName.split('//'):
            name_1 = {}
            name_1['name'] = n_1
            name_list_1.append(name_1)
        name_list_2 = []
        for n_2 in descriptionName.split('//'):
            name_2 = {}
            name_2['name'] = n_2
            name_list_2.append(name_2)
        if len(name_list_1) != len(name_list_2):
            print u"为模板删除应用集失败!,\033[041m输入的参数存在空值\033[0m"
            sys.exit(1)
        name_list_3_1 = []
        name_list_3_2 = []
        id_list_3 = []
        for n_3 in range(len(name_list_1)):
            name_3_1 = {}
            name_3_2 = {}
            id_3 = {}
            name_3_1['name'] = name_list_1[n_3]['name']
            name_3_2['name'] = name_list_2[n_3]['name']
            id_3['triggerid'] = self.trigger_get(name_list_1[n_3]['name'], name_list_2[n_3]['name'])
            if id_3['triggerid'] == []:
                print u"为模板 : \033[041m%s\033[0m 删除触发器 : \033[041m%s\033[0m 失败!,\033[041m触发器不存在\033[0m !" % \
                (name_list_1[n_3]['name'], name_list_2[n_3]['name'])
                continue
            name_list_3_1.append(name_3_1)
            name_list_3_2.append(name_3_2)
            id_list_3.append(id_3)
        for n_4 in range(len(name_list_3_1)):
            data = json.dumps({
                                "jsonrpc":"2.0",
                                "method":"trigger.delete",
                                "params":[
                                            id_list_3[n_4]['triggerid']
                                        ],
                                "auth":self.authID,
                                "id":1,
                            })
            request = urllib2.Request(self.url, data, self.header)     
            result = urllib2.urlopen(request)
            response = json.loads(result.read())
            result.close()
            if response.get('result','') != '':
                print u"为模板 : \033[042m%s\033[0m 删除触发器 : \033[042m%s\033[0m 成功!,并且触发器ID为 : \033[042m%s\033[0m" % \
                (name_list_3_1[n_4]['name'], name_list_3_2[n_4]['name'], ",".join(response['result']['triggerids']))
            elif response.get('error','') != '':
                print u"为模板 : \033[041m%s\033[0m 删除触发器 : \033[041m%s\033[0m 失败!\
                \n\033[041m%s\033[0m" % (name_list_3_1[n_4]['name'], name_list_3_2[n_4]['name'], response['error']['data'])
    #![05_创建主机]
    def host_get(self, hostName):
        data = json.dumps({
                            "jsonrpc":"2.0",
                            "method":"host.get",
                            "params":{
                                    "output": "extend",
                                    "filter": {
                                                "host": hostName
                                            },
                                    },
                            "auth":self.authID,
                            "id":1,
                        })
        request = urllib2.Request(self.url, data, self.header)     
        result = urllib2.urlopen(request)
        response = json.loads(result.read())
        result.close()
        if response.get('result','') != []:
            return response['result'][0]['hostid']
        else:
            return response['result']

    def host_create(self, hostName):
        default_id = {}
        default_id['groupid'] = self.hostGroup_get('000_LocalHost')
        if default_id['groupid'] == []:
            self.hostGroup_create('000_LocalHost')
            default_id['groupid'] = self.hostGroup_get('000_LocalHost')
        name_list_1 = []
        for n_1 in hostName.split('//'):
            name_1 = {}
            name_1['name'] = n_1
            name_list_1.append(name_1)
        name_list_2 = []
        for n_2 in range(len(name_list_1)):
            name_2 = {}
            id_2 = {}
            name_2['name'] = name_list_1[n_2]['name']
            id_2['hostid'] = self.host_get(name_list_1[n_2]['name'])
            if id_2['hostid'] != []:
                print u"创建主机 : \033[041m%s\033[0m 失败!,主机重复创建" % name_list_1[n_2]['name']
                continue
            name_list_2.append(name_2)
        for n_3 in range(len(name_list_2)):
            data = json.dumps({
                               "jsonrpc":"2.0",
                               "method":"host.create",
                               "params":{
                                         "host": name_list_2[n_3]['name'],
                                         "interfaces": [
                                                            {
                                                                "type": 1,
                                                                "main": 1,
                                                                "useip": 1,
                                                                "ip": "127.0.0.1",
                                                                "dns": "",
                                                                "port": "10050"
                                                            }
                                                        ],
                                        "groups": [
                                                        {
                                                            "groupid": default_id['groupid']
                                                        }
                                                   ],
                                         },
                               "auth": self.authID,
                               "id":1                  
            })
            request = urllib2.Request(self.url, data, self.header)  
            result = urllib2.urlopen(request)
            response = json.loads(result.read())
            result.close()
            if response.get('result','') != '':
                print u"创建主机 : \033[042m%s\033[0m 成功!,主机ID为 : \033[042m%s\033[0m" % (name_list_2[n_3]['name'], ",".join(response['result']['hostids']))
            elif response.get('error','') != '':
                print u"创建主机 : \033[041m%s\033[0m 失败!\n\033[041m%s\033[0m" % (name_list_2[n_3]['name'], response['error']['data'])

    def host_delete(self, hostName):
        name_list_1 = []
        for n_1 in hostName.split('//'):
            name_1 = {}
            name_1['name'] = n_1
            name_list_1.append(name_1)
        name_list_2 = []
        id_list_2 = []
        for n_2 in range(len(name_list_1)):
            name_2 = {}
            id_2 = {}
            name_2['name'] = name_list_1[n_2]['name']
            id_2['hostid'] = self.host_get(name_list_1[n_2]['name'])
            if id_2['hostid'] == []:
                print u"删除主机组 : \033[041m%s\033[0m 失败!,主机组不存在" % name_list_1[n_2]['name']
                continue
            name_list_2.append(name_2)
            id_list_2.append(id_2)
        for n_3 in range(len(name_list_2)):
            data = json.dumps({
                                "jsonrpc": "2.0",
                                "method": "host.delete",
                                "params": [
                                            id_list_2[n_3]['hostid']
                                        ],
                                "auth": self.authID,
                                "id": 1
                            })
            request = urllib2.Request(self.url, data, self.header)
            result = urllib2.urlopen(request)
            response = json.loads(result.read())
            result.close()
            if response.get('result','') != '':
                print u"删除主机 : \033[042m%s\033[0m 成功!,主机组ID为 : \033[042m%s\033[0m" % (name_list_2[n_3]['name'], ",".join(response['result']['hostids']))
            elif response.get('error','') != '':
                print u"删除主机 : \033[041m%s\033[0m 失败!\n\033[041m%s\033[0m" % (name_list_2[n_3]['name'], response['error']['data'])
    #![06_为主机创建接口]
    def interface_get(self, hostName, ipName, portName):
        data = json.dumps({
                            "jsonrpc":"2.0",
                            "method":"hostinterface.get",
                            "params":{
                                    "output": "extend",
                                    "hostids": self.host_get(hostName),
                                    "filter":{
                                            "ip": ipName,
                                            "port": portName
                                        },
                                    },
                            "auth":self.authID,
                            "id":1,
                        })
        request = urllib2.Request(self.url, data, self.header)     
        result = urllib2.urlopen(request)
        response = json.loads(result.read())
        result.close()
        if response.get('result','') != []:
            return response['result'][0]['interfaceid']
        else:
            return response['result']

    def interface_massadd(self, hostName, ipName, portName, defaultName, typeName):
        name_list_1 = []
        for n_1 in hostName.split('//'):
            name_1 = {}
            name_1['name'] = n_1
            name_list_1.append(name_1)
        name_list_2 = []
        for n_2 in ipName.split('//'):
            name_2 = {}
            name_2['name'] = n_2
            name_list_2.append(name_2)
        name_list_3 = []
        for n_3 in portName.split('//'):
            name_3 = {}
            name_3['name'] = n_3
            name_list_3.append(name_3)
        name_list_4 = []
        for n_4 in defaultName.split('//'):
            name_4 = {}
            name_4['name'] = n_4
            name_list_4.append(name_4)
        name_list_5 = []
        for n_5 in typeName.split('//'):
            name_5 = {}
            name_5['name'] = n_5
            name_list_5.append(name_5)  
        if len(name_list_1) != len(name_list_2) or \
        len(name_list_1) != len(name_list_3) or \
        len(name_list_1) != len(name_list_4) or \
        len(name_list_1) != len(name_list_5):
            print u"为主机附加接口失败!,\033[041m输入的参数存在空值\033[0m"
            sys.exit(1)
        name_list_6_1 = []
        name_list_6_2 = []
        name_list_6_3 = []
        name_list_6_4 = []
        name_list_6_5 = []
        id_list_6 = []
        for n_6 in range(len(name_list_1)):
            name_6_1 = {}
            name_6_2 = {}
            name_6_3 = {}
            name_6_4 = {}
            name_6_5 = {}
            id_6 = {}
            name_6_1['name'] = name_list_1[n_6]['name']
            name_6_2['name'] = name_list_2[n_6]['name']
            name_6_3['name'] = name_list_3[n_6]['name']
            name_6_4['name'] = name_list_4[n_6]['name']
            name_6_5['name'] = name_list_5[n_6]['name']
            id_6['hostid'] = self.host_get(name_list_1[n_6]['name'])
            if id_6['hostid'] == []:
                print u"为主机附加接口失败!,主机 : \033[041m%s\033[0m 不存在" % name_list_1[n_6]['name']
                continue
            name_list_6_1.append(name_6_1)
            name_list_6_2.append(name_6_2)
            name_list_6_3.append(name_6_3)
            name_list_6_4.append(name_6_4)
            name_list_6_5.append(name_6_5)
            id_list_6.append(id_6)
        name_list_7_1 = []
        name_list_7_2 = []
        name_list_7_3 = []
        name_list_7_4 = []
        name_list_7_5 = []
        id_list_7 = []
        for n_7 in range(len(name_list_1)):
            name_7_1 = {}
            name_7_2 = {}
            name_7_3 = {}
            name_7_4 = {}
            name_7_5 = {}
            id_7_1 = {}
            id_7_2 = {}
            name_7_1['name'] = name_list_1[n_7]['name']
            name_7_2['name'] = name_list_2[n_7]['name']
            name_7_3['name'] = name_list_3[n_7]['name']
            name_7_4['name'] = name_list_4[n_7]['name']
            name_7_5['name'] = name_list_5[n_7]['name']
            id_7_1['hostid'] = id_list_6[n_7]['hostid']
            id_7_2['interfaceid'] = self.interface_get(name_list_1[n_7]['name'], name_list_2[n_7]['name'], name_list_3[n_7]['name'])
            if id_7_2['interfaceid'] != []:
                print u"为主机 : \033[041m%s\033[0m 附加接口失败!,接口 : \033[041m%s\033[0m 已存在,并且接口ID为 : \033[042m%s\033[0m" % \
                    (name_list_1[n_7]['name'], name_list_3[n_7]['name'], id_7_2['interfaceid'])
                continue
            name_list_7_1.append(name_7_1)
            name_list_7_2.append(name_7_2)
            name_list_7_3.append(name_7_3)
            name_list_7_4.append(name_7_4)
            name_list_7_5.append(name_7_5)
            id_list_7.append(id_7_1)
        for n_8 in range(len(name_list_7_1)):
            data = json.dumps({
                                "jsonrpc": "2.0",
                                "method": "hostinterface.massadd",
                                "params": {
                                            "hosts": [
                                                        {
                                                            "hostid": id_list_7[n_8]['hostid']
                                                        }
                                                ],
                                            "interfaces": [
                                                            {
                                                                "dns": "",                                                                    
                                                                "ip": name_list_7_2[n_8]['name'],
                                                                "main": name_list_7_4[n_8]['name'],
                                                                "port": name_list_7_3[n_8]['name'],
                                                                "type": name_list_7_5[n_8]['name'],
                                                                "useip": 1,
                                                            }
                                                        ],
                                        },
                                "auth": self.authID,
                                "id": 1
                            })
            request = urllib2.Request(self.url, data, self.header)
            result = urllib2.urlopen(request)
            response = json.loads(result.read())
            result.close()
            if response.get('result','') != '':
                print u"为主机 : \033[042m%s\033[0m 附加接口 : \033[042m%s\033[0m 成功!,并且接口ID为 : \033[042m%s\033[0m" % \
                (name_list_7_1[n_8]['name'], name_list_7_3[n_8]['name'], ",".join(response['result']['interfaceids']['interfaceids']))
            elif response.get('error','') != '':
                print u"为主机 : \033[041m%s\033[0m 附加接口 : \033[041m%s\033[0m 失败!\
                \n\033[041m%s\033[0m" % (name_list_7_1[n_8]['name'],name_list_7_3[n_8]['name'], response['error']['data'])

    def interface_massRemove(self, hostName, ipName, portName):
        name_list_1 = []
        for n_1 in hostName.split('//'):
            name_1 = {}
            name_1['name'] = n_1
            name_list_1.append(name_1)
        name_list_2 = []
        for n_2 in ipName.split('//'):
            name_2 = {}
            name_2['name'] = n_2
            name_list_2.append(name_2)
        name_list_3 = []
        for n_3 in portName.split('//'):
            name_3 = {}
            name_3['name'] = n_3
            name_list_3.append(name_3)
        if len(name_list_1) != len(name_list_2) or \
        len(name_list_1) != len(name_list_3):
            print u"为主机移除接口失败!,\033[041m输入的参数存在空值\033[0m"
            sys.exit(1)
        name_list_4_1 = []
        name_list_4_2 = []
        name_list_4_3 = []
        id_list_4 = []
        for n_4 in range(len(name_list_1)):
            name_4_1 = {}
            name_4_2 = {}
            name_4_3 = {}
            id_4 = {}
            name_4_1['name'] = name_list_1[n_4]['name']
            name_4_2['name'] = name_list_2[n_4]['name']
            name_4_3['name'] = name_list_3[n_4]['name']
            id_4['hostid'] = self.host_get(name_list_1[n_4]['name'])
            if id_4['hostid'] == []:
                print u"为主机 : \033[041m%s\033[0m 移除接口失败!,主机不存在" % name_list_1[n_4]['name']
                continue
            name_list_4_1.append(name_4_1)
            name_list_4_2.append(name_4_2)
            name_list_4_3.append(name_4_3)
            id_list_4.append(id_4)
        name_list_5_1 = []
        name_list_5_2 = []
        name_list_5_3 = []
        id_list_5 = []
        for n_5 in range(len(name_list_1)):
            name_5_1 = {}
            name_5_2 = {}
            name_5_3 = {}
            id_5_1 = {}
            id_5_2 = {}
            name_5_1['name'] = name_list_1[n_5]['name']
            name_5_2['name'] = name_list_2[n_5]['name']
            name_5_3['name'] = name_list_3[n_5]['name']
            id_5_1['hostid'] = id_list_4[n_5]['hostid']
            id_5_2['interfaceid'] = self.interface_get(name_list_1[n_5]['name'], name_list_2[n_5]['name'], name_list_3[n_5]['name'])
            if id_5_2['interfaceid'] == []:
                print u"为主机 : \033[041m%s\033[0m 移除接口失败!,接口 : \033[041m%s\033[0m 不存在" % (name_list_1[n_5]['name'], name_list_3[n_5]['name'])
                continue
            name_list_5_1.append(name_5_1)
            name_list_5_2.append(name_5_2)
            name_list_5_3.append(name_5_3)
            id_list_5.append(id_5_1)       
        for n_6 in range(len(name_list_5_1)):
            data = json.dumps({
                                "jsonrpc": "2.0",
                                "method": "hostinterface.massremove",
                                "params": {
                                            "hosts": [
                                                        {
                                                            "hostids": id_list_5[n_6]['hostid']
                                                        }
                                                ],
                                            "interfaces": [
                                                            {
                                                                "dns": "",                                                                    
                                                                "ip": name_list_5_2[n_6]['name'],
                                                                "port": name_list_5_3[n_6]['name'],
                                                            }
                                                        ],
                                        },
                                "auth": self.authID,
                                "id": 1
                            })
            request = urllib2.Request(self.url, data, self.header)
            result = urllib2.urlopen(request)
            response = json.loads(result.read())
            result.close()
            if response.get('result','') != '':
                print u"为主机 : \033[042m%s\033[0m 移除接口 : \033[042m%s\033[0m 成功!,并且接口ID为 : \033[042m%s\033[0m" % \
                (name_list_5_1[n_6]['name'], name_list_5_3[n_6]['name'], ",".join([str(i) for i in response['result']['interfaceids']]))
            elif response.get('error','') != '':
                print u"为主机 : \033[041m%s\033[0m 移除接口 : \033[041m%s\033[0m 失败!\
                \n\033[041m%s\033[0m" % (name_list_5_1[n_6]['name'], name_list_5_3[n_6]['name'], response['error']['data'])
    #![07_为主机关联模板]
    def host_massadd(self, hostName, templateName):
        name_list_1 = []
        for n_1 in hostName.split('//'):
            name_1 = {}
            name_1['name'] = n_1
            name_list_1.append(name_1)
        name_list_2 = []
        for n_2 in templateName.split('//'):
            name_2 = {}
            name_2['name'] = n_2
            name_list_2.append(name_2)
        if len(name_list_1) != len(name_list_2):
            print u"为主机附加模板失败!,\033[041m输入的参数存在空值\033[0m"
            sys.exit(1)
        name_list_3_1 = []
        name_list_3_2 = []
        id_list_3 = []
        for n_3 in range(len(name_list_1)):
            name_3_1 = {}
            name_3_2 = {}
            id_3 = {}
            name_3_1['name'] = name_list_1[n_3]['name']
            name_3_2['name'] = name_list_2[n_3]['name']
            id_3['hostid'] = self.host_get(name_list_1[n_3]['name'])
            if id_3['hostid'] == []:
                print u"为主机 : \033[041m%s\033[0m 附加模板失败!,主机不存在" % name_list_1[n_3]['name']
                continue
            name_list_3_1.append(name_3_1)
            name_list_3_2.append(name_3_2)
            id_list_3.append(id_3)
        name_list_4_1 = []
        name_list_4_2 = []
        id_list_4_1 = []
        id_list_4_2 = []
        for n_4 in range(len(name_list_3_1)):
            name_4_1 = {}
            name_4_2 = {}
            id_4_1 = {}
            id_4_2 = {}
            name_4_1['name'] = name_list_3_1[n_4]['name']
            name_4_2['name'] = name_list_3_2[n_4]['name']
            id_4_1['hostid'] = id_list_3[n_4]['hostid']
            id_4_2['templateid'] = self.template_get(name_list_3_2[n_4]['name'])
            if id_4_2['templateid'] == []:
                print u"为主机附加模板 : \033[041m%s\033[0m 失败!,模板不存在!" % name_list_3_2[n_4]['name']
                continue
            name_list_4_1.append(name_4_1)
            name_list_4_2.append(name_4_2)
            id_list_4_1.append(id_4_1)
            id_list_4_2.append(id_4_2)
        for n_5 in range(len(name_list_4_1)):
            data = json.dumps({
                                "jsonrpc": "2.0",
                                "method": "host.massadd",
                                "params": {
                                            "hosts": [
                                                            {
                                                                "hostid": id_list_4_1[n_5]['hostid']
                                                            }
                                                        ],
                                            "templates": [
                                                        {
                                                            "templateid": id_list_4_2[n_5]['templateid']
                                                        }
                                                    ],
                                        },
                                "auth": self.authID,
                                "id": 1
                            })
            request = urllib2.Request(self.url, data, self.header)
            result = urllib2.urlopen(request)
            response = json.loads(result.read())
            result.close()
            if response.get('result','') != '':
                print u"为主机 : \033[042m%s\033[0m 附加模板 : \033[042m%s\033[0m 成功!,并且主机ID为 : \033[042m%s\033[0m" % \
                (name_list_4_1[n_5]['name'],name_list_4_2[n_5]['name'], ",".join(response['result']['hostids']))
            elif response.get('error','') != '':
                print u"为主机 : \033[041m%s\033[0m 附加模板 : \033[041m%s\033[0m 失败!,并且主机ID为 : \033[041m%s\033[0m \
                \n\033[041m%s\033[0m" % (name_list_4_1[n_5]['name'],name_list_4_2[n_5]['name'], id_list_4_2[n_5]['templateid'], response['error']['data'])
    
    def host_massremove(self, hostName, templateName):
        name_list_1 = []
        for n_1 in hostName.split('//'):
            name_1 = {}
            name_1['name'] = n_1
            name_list_1.append(name_1)
        name_list_2 = []
        for n_2 in templateName.split('//'):
            name_2 = {}
            name_2['name'] = n_2
            name_list_2.append(name_2)
        if len(name_list_1) != len(name_list_2):
            print u"为主机附加模板失败!,\033[041m输入的参数存在空值\033[0m"
            sys.exit(1)
        name_list_3_1 = []
        name_list_3_2 = []
        id_list_3 = []
        for n_3 in range(len(name_list_1)):
            name_3_1 = {}
            name_3_2 = {}
            id_3 = {}
            name_3_1['name'] = name_list_1[n_3]['name']
            name_3_2['name'] = name_list_2[n_3]['name']
            id_3['hostid'] = self.host_get(name_list_1[n_3]['name'])
            if id_3['hostid'] == []:
                print u"为主机 : \033[041m%s\033[0m 附加模板失败!,主机不存在" % name_list_1[n_3]['name']
                continue
            name_list_3_1.append(name_3_1)
            name_list_3_2.append(name_3_2)
            id_list_3.append(id_3)
        name_list_4_1 = []
        name_list_4_2 = []
        id_list_4_1 = []
        id_list_4_2 = []
        for n_4 in range(len(name_list_3_1)):
            name_4_1 = {}
            name_4_2 = {}
            id_4_1 = {}
            id_4_2 = {}
            name_4_1['name'] = name_list_3_1[n_4]['name']
            name_4_2['name'] = name_list_3_2[n_4]['name']
            id_4_1['hostid'] = id_list_3[n_4]['hostid']
            id_4_2['templateid'] = self.template_get(name_list_3_2[n_4]['name'])
            if id_4_2['templateid'] == []:
                print u"为主机附加模板 : \033[041m%s\033[0m 失败!,模板不存在!" % name_list_3_2[n_4]['name']
                continue
            name_list_4_1.append(name_4_1)
            name_list_4_2.append(name_4_2)
            id_list_4_1.append(id_4_1)
            id_list_4_2.append(id_4_2)
        for n_5 in range(len(name_list_4_1)):
            data = json.dumps({
                                "jsonrpc": "2.0",
                                "method": "host.massremove",
                                "params": {
                                            "hostids": [
                                                            id_list_4_1[n_5]['hostid']
                                                    ],
                                            "templateids_clear": id_list_4_2[n_5]['templateid']
                                        },
                                "auth": self.authID,
                                "id": 1
                            })
            request = urllib2.Request(self.url, data, self.header)
            result = urllib2.urlopen(request)
            response = json.loads(result.read())
            result.close()
            if response.get('result','') != '':
                print u"为主机 : \033[042m%s\033[0m 移除模板 : \033[042m%s\033[0m 成功!,并且主机ID为 : \033[042m%s\033[0m" % \
                (name_list_4_1[n_5]['name'],name_list_4_2[n_5]['name'], ",".join(response['result']['hostids']))
            elif response.get('error','') != '':
                print u"为主机 : \033[041m%s\033[0m 移除模板 : \033[041m%s\033[0m 失败!\
                \n\033[041m%s\033[0m" % (name_list_4_1[n_5]['name'],name_list_4_2[n_5]['name'], response['error']['data'])
    #![08_创建主机组]
    def hostGroup_get(self, hostGroupName):
        data = json.dumps({
                            "jsonrpc":"2.0",
                            "method":"hostgroup.get",
                            "params":{
                                    "output": "extend",
                                    "filter": {
                                                "name": hostGroupName
                                            }
                                    },
                            "auth":self.authID,
                            "id":1,
                        })
        request = urllib2.Request(self.url, data, self.header)   
        result = urllib2.urlopen(request)
        response = json.loads(result.read())
        result.close()
        if response.get('result','') != []:
            return response['result'][0]['groupid']
        else:
            return response['result']
             
    def hostGroup_create(self, hostGroupName):
        name_list_1 = []
        for n_1 in hostGroupName.split('//'):
            name_1 = {}
            name_1['name'] = n_1
            name_list_1.append(name_1)
        name_list_2 = []
        for n_2 in range(len(name_list_1)):
            name_2 = {}
            id_2 = {}
            name_2['name'] = name_list_1[n_2]['name']
            id_2['groupid'] = self.hostGroup_get(name_list_1[n_2]['name'])
            if id_2['groupid'] != []:
                print u"创建主机组 : \033[041m%s\033[0m 失败!,主机组重复创建" % name_list_1[n_2]['name']
                continue
            name_list_2.append(name_2)
        for n_3 in range(len(name_list_2)):
            data = json.dumps({
                                "jsonrpc": "2.0",
                                "method": "hostgroup.create",
                                "params": {
                                "name": name_list_2[n_3]['name']
                                        },
                                "auth": self.authID,
                                "id": 1
                            })
            request = urllib2.Request(self.url, data, self.header)  
            result = urllib2.urlopen(request)
            response = json.loads(result.read())
            result.close()
            if response.get('result','') != '':
                print u"创建主机组 : \033[042m%s\033[0m 成功!,主机组ID为 : \033[042m%s\033[0m" % (name_list_2[n_3]['name'], ",".join(response['result']['groupids']))
            elif response.get('error','') != '':
                print u"创建主机组 : \033[041m%s\033[0m 失败!\n\033[041m%s\033[0m" % (name_list_2[n_3]['name'], response['error']['data'])   
 
    def hostGroup_delete(self, hostGroupName):
        name_list_1 = []
        for n_1 in hostGroupName.split('//'):
            name_1 = {}
            name_1['name'] = n_1
            name_list_1.append(name_1)
        name_list_2 = []
        id_list_2 = []
        for n_2 in range(len(name_list_1)):
            name_2 = {}
            id_2 = {}
            name_2['name'] = name_list_1[n_2]['name']
            id_2['groupid'] = self.hostGroup_get(name_list_1[n_2]['name'])
            if id_2['groupid'] == []:
                print u"删除主机组 : \033[041m%s\033[0m 失败!,主机组不存在" % name_list_1[n_2]['name']
                continue
            name_list_2.append(name_2)
            id_list_2.append(id_2)
        for n_3 in range(len(name_list_2)):
            data = json.dumps({
                                "jsonrpc": "2.0",
                                "method": "hostgroup.delete",
                                "params": [
                                            id_list_2[n_3]['groupid']
                                        ],
                                "auth": self.authID,
                                "id": 1
                            })
            request = urllib2.Request(self.url, data, self.header)
            result = urllib2.urlopen(request)
            response = json.loads(result.read())
            result.close()
            if response.get('result','') != '':
                print u"删除主机组 : \033[042m%s\033[0m 成功!,主机组ID为 : \033[042m%s\033[0m" % (name_list_2[n_3]['name'], ",".join(response['result']['groupids']))
            elif response.get('error','') != '':
                print u"删除主机组 : \033[041m%s\033[0m 失败!\n\033[041m%s\033[0m" % (name_list_2[n_3]['name'], response['error']['data'])
    #![09_为主机附加主机组]
    def hostGroup_massadd(self, hostName, hostGroupName):
        name_list_1 = []
        for n_1 in hostName.split('//'):
            name_1 = {}
            name_1['name'] = n_1
            name_list_1.append(name_1)
        name_list_2 = []
        for n_2 in hostGroupName.split('//'):
            name_2 = {}
            name_2['name'] = n_2
            name_list_2.append(name_2)
        if len(name_list_1) != len(name_list_2):
            print u"为主机附加主机组失败!,\033[041m输入的参数存在空值\033[0m"
            sys.exit(1)
        name_list_3_1 = []
        name_list_3_2 = []
        id_list_3 = []
        for n_3 in range(len(name_list_1)):
            name_3_1 = {}
            name_3_2 = {}
            id_3 = {}
            name_3_1['name'] = name_list_1[n_3]['name']
            name_3_2['name'] = name_list_2[n_3]['name']
            id_3['hostid'] = self.host_get(name_list_1[n_3]['name'])
            if id_3['hostid'] == []:
                print u"为主机 : \033[041m%s\033[0m 附加主机组失败!,主机不存在" % name_list_1[n_3]['name']
                continue
            name_list_3_1.append(name_3_1)
            name_list_3_2.append(name_3_2)
            id_list_3.append(id_3)
        name_list_4_1 = []
        name_list_4_2 = []
        id_list_4_1 = []
        id_list_4_2 = []
        for n_4 in range(len(name_list_3_1)):
            name_4_1 = {}
            name_4_2 = {}
            id_4_1 = {}
            id_4_2 = {}
            name_4_1['name'] = name_list_3_1[n_4]['name']
            name_4_2['name'] = name_list_3_2[n_4]['name']
            id_4_1['hostid'] = id_list_3[n_4]['hostid']
            id_4_2['groupid'] = self.hostGroup_get(name_list_3_2[n_4]['name'])
            if id_4_2['groupid'] == []:
                print u"为主机附加主机组 : \033[041m%s\033[0m 失败!,主机组不存在!" % name_list_3_2[n_4]['name']
                continue
            name_list_4_1.append(name_4_1)
            name_list_4_2.append(name_4_2)
            id_list_4_1.append(id_4_1)
            id_list_4_2.append(id_4_2)
        for n_5 in range(len(name_list_4_1)):
            data = json.dumps({
                                "jsonrpc": "2.0",
                                "method": "host.massadd",
                                "params": {
                                            "hosts": [
                                                            {
                                                                "hostid": id_list_4_1[n_5]['hostid']
                                                            }
                                                        ],
                                            "groups": [
                                                        {
                                                            "groupid": id_list_4_2[n_5]['groupid']
                                                        }
                                                    ],
                                        },
                                "auth": self.authID,
                                "id": 1
                            })
            request = urllib2.Request(self.url, data, self.header)
            result = urllib2.urlopen(request)
            response = json.loads(result.read())
            result.close()
            if response.get('result','') != '':
                print u"为主机 : \033[042m%s\033[0m 附加模板 : \033[042m%s\033[0m 成功!,并且主机ID为 : \033[042m%s\033[0m" % \
                (name_list_4_1[n_5]['name'],name_list_4_2[n_5]['name'], ",".join(response['result']['hostids']))
            elif response.get('error','') != '':
                print u"为主机 : \033[041m%s\033[0m 附加模板 : \033[041m%s\033[0m 失败!,并且主机ID为 : \033[041m%s\033[0m \
                \n\033[041m%s\033[0m" % (name_list_4_1[n_5]['name'],name_list_4_2[n_5]['name'], id_list_4_2[n_5]['groupid'], response['error']['data'])

    def hostGroup_massremove(self, hostName, hostGroupName):
        name_list_1 = []
        for n_1 in hostName.split('//'):
            name_1 = {}
            name_1['name'] = n_1
            name_list_1.append(name_1)
        name_list_2 = []
        for n_2 in hostGroupName.split('//'):
            name_2 = {}
            name_2['name'] = n_2
            name_list_2.append(name_2)
        if len(name_list_1) != len(name_list_2):
            print u"为主机移除主机组失败!,\033[041m输入的参数存在空值\033[0m"
            sys.exit(1)
        name_list_3_1 = []
        name_list_3_2 = []
        id_list_3 = []
        for n_3 in range(len(name_list_1)):
            name_3_1 = {}
            name_3_2 = {}
            id_3 = {}
            name_3_1['name'] = name_list_1[n_3]['name']
            name_3_2['name'] = name_list_2[n_3]['name']
            id_3['hostid'] = self.host_get(name_list_1[n_3]['name'])
            if id_3['hostid'] == []:
                print u"为主机 : \033[041m%s\033[0m 移除主机组失败!,主机不存在" % name_list_1[n_3]['name']
                continue
            name_list_3_1.append(name_3_1)
            name_list_3_2.append(name_3_2)
            id_list_3.append(id_3)
        name_list_4_1 = []
        name_list_4_2 = []
        id_list_4_1 = []
        id_list_4_2 = []
        for n_4 in range(len(name_list_3_1)):
            name_4_1 = {}
            name_4_2 = {}
            id_4_1 = {}
            id_4_2 = {}
            name_4_1['name'] = name_list_3_1[n_4]['name']
            name_4_2['name'] = name_list_3_2[n_4]['name']
            id_4_1['hostid'] = id_list_3[n_4]['hostid']
            id_4_2['groupid'] = self.hostGroup_get(name_list_3_2[n_4]['name'])
            if id_4_2['groupid'] == []:
                print u"为主机移除主机组 : \033[041m%s\033[0m 失败!,主机组不存在!" % name_list_3_2[n_4]['name']
                continue
            name_list_4_1.append(name_4_1)
            name_list_4_2.append(name_4_2)
            id_list_4_1.append(id_4_1)
            id_list_4_2.append(id_4_2)
        for n_5 in range(len(name_list_4_1)):
            data = json.dumps({
                                "jsonrpc": "2.0",
                                "method": "host.massremove",
                                "params": {
                                            "hostids": [
                                                            id_list_4_1[n_5]['hostid']
                                                    ],
                                            "groupids": id_list_4_2[n_5]['groupid']
                                        },
                                "auth": self.authID,
                                "id": 1
                            })
            request = urllib2.Request(self.url, data, self.header)
            result = urllib2.urlopen(request)
            response = json.loads(result.read())
            result.close()
            if response.get('result','') != '':
                print u"为主机 : \033[042m%s\033[0m 移除主机组 : \033[042m%s\033[0m 成功!,并且主机ID为 : \033[042m%s\033[0m" % \
                (name_list_4_1[n_5]['name'],name_list_4_2[n_5]['name'], ",".join(response['result']['hostids']))
            elif response.get('error','') != '':
                print u"为主机 : \033[041m%s\033[0m 移除主机组 : \033[041m%s\033[0m 失败!\
                \n\033[041m%s\033[0m" % (name_list_4_1[n_5]['name'],name_list_4_2[n_5]['name'], response['error']['data'])

if __name__ == "__main__":
    zabbix = zabbix_api()
    #![01_创建模板]
    parser = argparse.ArgumentParser(description='zabbix  api ', usage='%(prog)s [options]')
    parser.add_argument('-ct', nargs='+', metavar=('模板名称'), dest='ct', help=u"创建模板(多个可用//隔开)")
    parser.add_argument('-cte', nargs='?', metavar=('无参数'), dest='cte', default='cte', \
                        help=u"通过zabbix_api.xlsx的Sheet2表为A列的主机批量创建模板")
    parser.add_argument('-dt', metavar=('模板名称'), nargs='+', dest='dt', help=u"删除模板(多个可用//隔开)")
    parser.add_argument('-dte', nargs='?', metavar=('无参数'), dest='dte', default='dte', \
                        help=u"通过zabbix_api.xlsx的Sheet2表从A列批量删除模板")
    #![02_为模板创建应用集]
    parser.add_argument('-ca', nargs='+', metavar=('模板名称 应用集名称'), dest='ca', \
                        help=u"为模板(多个模板可用//隔开)创建应用集(多个应用集可用//隔开)")
    parser.add_argument('-cae', nargs='?', metavar=('无参数'), dest='cae',default='cae', \
                        help=u"通过zabbix_api.xlsx的Sheet5表为A列模板批量创建B列应用集")
    parser.add_argument('-da', nargs='+', metavar=('模板名称 应用集名称'), dest='da', \
                        help=u"为模板(多个模板可用//隔开)删除应用集(多个应用集可用//隔开)")
    parser.add_argument('-dae', nargs='?', metavar=('无参数'), dest='dae',default='dae', \
                        help=u"通过zabbix_api.xlsx的Sheet5表为A列模板批量删除B列应用集")
    #![03_为模板创建监控项]
    parser.add_argument('-ci', nargs='+', \
                        metavar=('模板名称 应用集名称 监控项名称 监控项键值 监控项信息类型 监控项更新间隔'), \
                        dest='ci', help=u"为模板(多个模板可用//隔开)创建监控项(多个监控项可用//隔开)")
    parser.add_argument('-cie', nargs='?', metavar=('无参数'), dest='cie',default='cie', \
                        help=u"通过zabbix_api.xlsx的Sheet5表为A列模板批量创建CDEF列监控项,并附加到B列应用集")
    parser.add_argument('-di', nargs='+', metavar=('模板名称 应用集名称'), dest='di', \
                        help=u"为模板(多个模板可用//隔开)删除监控项(多个监控项可用//隔开)")
    parser.add_argument('-die', nargs='?', metavar=('无参数'), dest='die',default='die', \
                        help=u"通过zabbix_api.xlsx的Sheet5表为A列模板批量删除C列监控项")
    #![04_为模板创建触发器]
    parser.add_argument('-ctg', nargs='+', \
                        metavar=('模板名称 监控项名称 触发器名称 触发器表达式'), \
                        dest='ctg', help=u"为监控项(多个监控项可用//隔开)创建触发器(多个触发器可用//隔开)")
    parser.add_argument('-ctge', nargs='?', metavar=('无参数'), dest='ctge',default='ctge', \
                        help=u"通过zabbix_api.xlsx的Sheet6表为A列模板的B列监控项批量创建CD列触发器")
    parser.add_argument('-dtg', nargs='+', metavar=('模板名称 触发器名称'), dest='dtg', \
                        help=u"为模板(多个模板可用//隔开)删除触发器(多个触发器可用//隔开)")
    parser.add_argument('-dtge', nargs='?', metavar=('无参数'), dest='dtge',default='dtge', \
                        help=u"通过zabbix_api.xlsx的Sheet6表为A列模板批量删除C列触发器")
    #![05_创建主机]
    parser.add_argument('-ch', nargs='+', metavar=('主机名称'), dest='ch', \
                        help=u"创建主机(多个可用//隔开)")
    parser.add_argument('-che', nargs='?', metavar=('无参数'), dest='che', default='che', \
                        help=u"通过zabbix_api.xlsx的Sheet4表从A列批量创建主机")
    parser.add_argument('-dh', nargs='+', metavar=('主机组名称'), dest='dh', help=u"删除主机组(多个可用//隔开)")
    parser.add_argument('-dhe', nargs='?', metavar=('无参数'), dest='dhe', default='dhe', \
                        help=u"通过zabbix_api.xlsx的Sheet1表从A列批量删除主机组")
    #![06_为主机创建接口]
    parser.add_argument('-mai', nargs='+', \
                        metavar=('主机名称 接口地址 接口端口 作为默认接口 接口类型'), \
                        dest='mai', help=u"为主机(多个主机可用//隔开)附加接口(多个接口可用//隔开)")
    parser.add_argument('-maie', nargs='?', metavar=('无参数'), dest='maie',default='maie', \
                        help=u"通过zabbix_api.xlsx的Sheet4表为A列主机批量附加BCDE列接口")
    parser.add_argument('-mri', nargs='+', metavar=('主机名称 接口地址 接口端口'), dest='mri', \
                        help=u"为主机(多个主机可用//隔开)移除接口(多个接口可用//隔开)")
    parser.add_argument('-mrie', nargs='?', metavar=('无参数'), dest='mrie', default='mrie', \
                        help=u"通过zabbix_api.xlsx的Sheet4表为A列主机批量移除BC列接口")
    #![07_为主机关联模板]
    parser.add_argument('-mat', nargs='+', metavar=('主机组名称 模板名称'), dest='mat', \
                        help=u"为主机(多个主机可用//隔开)附加模板(多个模板可用//隔开)")
    parser.add_argument('-mate', nargs='?', metavar=('无参数'), dest='mate',default='mate', \
                        help=u"通过zabbix_api.xlsx的Sheet3表为A列主机组批量附加B列模板")
    parser.add_argument('-mrt', nargs='+', metavar=('主机组名称 模板名称'), dest='mrt', \
                        help=u"为主机(多个主机可用//隔开)移除模板(多个模板可用//隔开)")
    parser.add_argument('-mrte', nargs='?', metavar=('无参数'), dest='mrte', default='mrte',\
                        help=u"通过zabbix_api.xlsx的Sheet3表为A列主机组批量移除B列模板")
    #![08_创建主机组]
    parser.add_argument('-cg', nargs='+', metavar=('主机组名称'), dest='cg', help=u"创建主机组(多个可用//隔开)")
    parser.add_argument('-cge', nargs='?', metavar=('无参数'), dest='cge', default='cge', \
                        help=u"通过zabbix_api.xlsx的Sheet1表从A列批量创建主机组")
    parser.add_argument('-dg', nargs='+', metavar=('主机组名称'), dest='dg', help=u"删除主机组(多个可用//隔开)")
    parser.add_argument('-dge', nargs='?', metavar=('无参数'), dest='dge', default='dge', \
                        help=u"通过zabbix_api.xlsx的Sheet1表从A列批量删除主机组")
    #![09_为主机附加主机组]
    parser.add_argument('-mag', nargs='+', metavar=('主机名称 模板名称'), dest='mag', \
                        help=u"为主机(多个主机可用//隔开)附加主机组(多个主机组可用//隔开)")
    parser.add_argument('-mage', nargs='?', metavar=('无参数'), dest='mage',default='mage', \
                        help=u"通过zabbix_api.xlsx的Sheet3表为A列主机批量附加B列主机组")
    parser.add_argument('-mrg', nargs='+', metavar=('主机组名称 模板名称'), dest='mrg', \
                        help=u"为主机(多个主机可用//隔开)移除主机组(多个主机组可用//隔开)")
    parser.add_argument('-mrge', nargs='?', metavar=('无参数'), dest='mrge', default='mrge',\
                        help=u"通过zabbix_api.xlsx的Sheet3表为A列主机组批量移除B列主机组")
    parser.add_argument('-v', '--version', action='version', version='%(prog)s 如有问题请联系作者QQ1284524409', help=u"如有问题请联系作者QQ1284524409")
    if len(sys.argv) == 1:
        print parser.print_help()
    else:
        args = parser.parse_args()
        #![01_创建模板]
        if args.ct:
            zabbix.template_create(args.ct[0])
        elif args.cte != 'cte':
            workbook = xlrd.open_workbook('zabbix_api.xlsx')
            for row in xrange(workbook.sheets()[0].nrows):
                if row == 0:
                    continue
                else:
                    templateName = workbook.sheets()[0].cell(row, 0).value
                    if templateName == '':
                        break
                    try:
                        zabbix.template_create(templateName)
                    except Exception as e:
                        print u"Sheet2表第\033[041m%s\033[0m行数据异常\n\033[041m%s\033[0m" % (row + 1, e)
                        sys.exit(1)
        elif args.dt:
            zabbix.template_delete(args.dt[0])
        elif args.dte != 'dte':
            workbook = xlrd.open_workbook('zabbix_api.xlsx')
            for row in xrange(workbook.sheets()[0].nrows):
                if row == 0:
                    continue
                else:
                    templateName = workbook.sheets()[0].cell(row, 0).value
                    if templateName == '':
                        break
                    try:
                        zabbix.template_delete(templateName)
                    except Exception as e:
                        print u"Sheet2表第\033[041m%s\033[0m行数据异常\n\033[041m%s\033[0m" % (row + 1, e)
                        sys.exit(1)
        #![02_为模板创建应用集]
        elif args.ca:
            zabbix.application_create(args.ca[0], args.ca[1])
        elif args.cae != 'cae':
            workbook = xlrd.open_workbook('zabbix_api.xlsx')
            for x in xrange(workbook.sheets()[1].nrows):
                if x == 0:
                    continue
                else:
                    templateName = workbook.sheets()[1].cell(x, 0).value
                    if templateName == '':
                        break
                    applicationName = workbook.sheets()[1].cell(x, 1).value
                    if applicationName == '':
                        break
                    try:
                        zabbix.application_create(templateName, applicationName)
                    except Exception as e:
                        print u"Sheet5表第\033[041m%s\033[0m行数据异常\n\033[041m%s\033[0m" % (x + 1, e)
                        sys.exit(1)
        elif args.da:
            zabbix.application_delete(args.da[0], args.da[1])
        elif args.dae != 'dae':
            workbook = xlrd.open_workbook('zabbix_api.xlsx')
            for x in xrange(workbook.sheets()[1].nrows):
                if x == 0:
                    continue
                else:
                    templateName = workbook.sheets()[1].cell(x, 0).value
                    if templateName == '':
                        break
                    applicationName = workbook.sheets()[1].cell(x, 1).value
                    if applicationName == '':
                        break
                    try:
                        zabbix.application_delete(templateName, applicationName)
                    except Exception as e:
                        print u"Sheet5表第\033[041m%s\033[0m行数据异常\n\033[041m%s\033[0m" % (x + 1, e)
                        sys.exit(1)
        #![03_为模板创建监控项]
        elif args.ci:
            zabbix.item_create(args.ci[0], args.ci[1], args.ci[2], args.ci[3], args.ci[4], args.ci[5])
        elif args.cie != 'cie':
            workbook = xlrd.open_workbook('zabbix_api.xlsx')
            for x in xrange(workbook.sheets()[6].nrows):
                if x == 0:
                    continue
                else:
                    templateName = workbook.sheets()[2].cell(x, 0).value
                    if templateName == '':
                        break
                    itemApplication = workbook.sheets()[2].cell(x, 1).value
                    if itemApplication == '':
                        break
                    itemName = workbook.sheets()[2].cell(x, 2).value
                    if itemName == '':
                        break
                    itemKey = workbook.sheets()[2].cell(x, 3).value
                    if itemKey == '':
                        break
                    itemValueType = workbook.sheets()[2].cell(x, 4).value
                    if itemValueType == '':
                        break
                    itemDely = workbook.sheets()[2].cell(x, 5).value
                    if itemDely == '':
                        break
                    try:
                        zabbix.item_create(templateName, itemApplication, itemName, itemKey, str(int(itemValueType)), itemDely)
                    except Exception as e:
                        print u"Sheet5表第\033[041m%s\033[0m行数据异常\n\033[041m%s\033[0m" % (x + 1, e)
                        sys.exit(1)
        elif args.di:
            zabbix.item_delete(args.di[0], args.di[1])
        elif args.die != 'die':
            workbook = xlrd.open_workbook('zabbix_api.xlsx')
            for x in xrange(workbook.sheets()[2].nrows):
                if x == 0:
                    continue
                else:
                    templateName = workbook.sheets()[2].cell(x, 0).value
                    if templateName == '':
                        break
                    itemName = workbook.sheets()[2].cell(x, 1).value
                    if itemName == '':
                        break
                    try:
                        zabbix.item_delete(templateName, itemName)
                    except Exception as e:
                        print u"Sheet5表第\033[041m%s\033[0m行数据异常\n\033[041m%s\033[0m" % (x + 1, e)
                        sys.exit(1)
        #![04_为模板创建触发器]
        elif args.ctg:
            zabbix.trigger_create(args.ctg[0], args.ctg[1], args.ctg[2], args.ctg[3])
        elif args.ctge != 'ctge':
            workbook = xlrd.open_workbook('zabbix_api.xlsx')
            for x in xrange(workbook.sheets()[3].nrows):
                if x == 0:
                    continue
                else:
                    templateName = workbook.sheets()[3].cell(x, 0).value
                    if templateName == '':
                        break
                    itemName = workbook.sheets()[3].cell(x, 1).value
                    if itemName == '':
                        break
                    descriptionName = workbook.sheets()[3].cell(x, 2).value
                    if descriptionName == '':
                        break
                    expressionName = workbook.sheets()[3].cell(x, 3).value
                    if expressionName == '':
                        break
                    try:
                        zabbix.trigger_create(templateName, itemName, descriptionName, expressionName)
                    except Exception as e:
                        print u"Sheet5表第\033[041m%s\033[0m行数据异常\n\033[041m%s\033[0m" % (x + 1, e)
                        sys.exit(1)
        elif args.dtg:
            zabbix.trigger_delete(args.dtg[0], args.dtg[1])
        elif args.dtge != 'dtge':
            workbook = xlrd.open_workbook('zabbix_api.xlsx')
            for x in xrange(workbook.sheets()[3].nrows):
                if x == 0:
                    continue
                else:
                    templateName = workbook.sheets()[3].cell(x, 0).value
                    if templateName == '':
                        break
                    triggerName = workbook.sheets()[3].cell(x, 2).value
                    if triggerName == '':
                        break
                    try:
                        zabbix.trigger_delete(templateName, triggerName)
                    except Exception as e:
                        print u"Sheet5表第\033[041m%s\033[0m行数据异常\n\033[041m%s\033[0m" % (x + 1, e)
                        sys.exit(1)
        #![05_创建主机]
        elif args.ch:
            zabbix.host_create(args.ch[0])
        elif args.che != 'che':
            workbook = xlrd.open_workbook('zabbix_api.xlsx')
            for row in xrange(workbook.sheets()[4].nrows):
                if row == 0:
                    continue
                else:                    
                    hostName = workbook.sheets()[4].cell(row, 0).value
                    if hostName == '':
                        break
                    try:
                        zabbix.host_create(hostName)
                    except Exception as e:
                        print u"Sheet4表第\033[041m%s\033[0m行数据异常\n\033[041m%s\033[0m" % (row + 1, e)
                        sys.exit(1)
        elif args.dh:
            zabbix.host_delete(args.dh[0])
        elif args.dhe != 'dhe':
            workbook = xlrd.open_workbook('zabbix_api.xlsx')
            for row in xrange(workbook.sheets()[4].nrows):
                if row == 0:
                    continue
                else:
                    hosthost = workbook.sheets()[4].cell(row, 0).value
                    if hosthost == '':
                        break
                    try:
                        zabbix.host_delete(hosthost)
                    except Exception as e:
                        print u"Sheet4表第\033[041m%s\033[0m行数据异常\n\033[041m%s\033[0m" % (row + 1, e)
                        sys.exit(1)
        #![06_为主机创建接口]
        elif args.mai:
            zabbix.interface_massadd(args.mai[0], args.mai[1], args.mai[2], args.mai[3], args.mai[4])
        elif args.maie != 'maie':
            workbook = xlrd.open_workbook('zabbix_api.xlsx')
            for col1 in xrange(workbook.sheets()[5].nrows):
                if col1 == 0:
                    continue
                else:
                    hostName = workbook.sheets()[5].cell(col1, 0).value
                    if hostName == '':
                        break
                    ipName = workbook.sheets()[5].cell(col1, 1).value
                    if ipName == '':
                        break
                    portName = workbook.sheets()[5].cell(col1, 2).value
                    if portName == '':
                        break
                    defaultName = workbook.sheets()[5].cell(col1, 3).value
                    if defaultName == '':
                        break
                    typeName = workbook.sheets()[5].cell(col1, 4).value
                    if typeName == '':
                        break
                    try:
                        zabbix.interface_massadd(hostName, ipName, str(int(portName)), str(int(defaultName)), str(int(typeName)))
                    except Exception as e:
                        print u"Sheet4表第\033[041m%s\033[0m行数据异常\n\033[041m%s\033[0m" % (col1 + 1, e)
                        sys.exit(1)
        elif args.mri:
            zabbix.interface_massRemove(args.mri[0], args.mri[1], args.mri[2])
        elif args.mrie != 'mrie':
            workbook = xlrd.open_workbook('zabbix_api.xlsx')
            for col1 in xrange(workbook.sheets()[5].nrows):
                if col1 == 0:
                    continue
                else:
                    hostName = workbook.sheets()[5].cell(col1, 0).value
                    if hostName == '':
                        break
                    ipName = workbook.sheets()[5].cell(col1, 1).value
                    if ipName == '':
                        break
                    portName = workbook.sheets()[5].cell(col1, 2).value
                    if portName == '':
                        break
                    try:
                        zabbix.interface_massRemove(hostName, ipName, str(int(portName)))
                    except Exception as e:
                        print u"Sheet4表第\033[041m%s\033[0m行数据异常\n\033[041m%s\033[0m" % (col1 + 1, e)
                        sys.exit(1)
        #![07_为主机关联模板]
        elif args.mat:
            zabbix.host_massadd(args.mat[0], args.mat[1])
        elif args.mate != 'mate':
            workbook = xlrd.open_workbook('zabbix_api.xlsx')
            for n_1 in xrange(workbook.sheets()[6].nrows):
                if n_1 == 0:
                    continue
                else:
                    hostgroup = workbook.sheets()[6].cell(n_1, 0).value
                    if hostgroup == '':
                        break
                    templateName = workbook.sheets()[6].cell(n_1, 1).value
                    if templateName == '':
                        break
                    try:
                        zabbix.host_massadd(hostgroup, templateName)
                    except Exception as e:
                        print u"Sheet3表第\033[041m%s\033[0m行数据异常\n\033[041m%s\033[0m" % (n_1 + 1, e)
                        sys.exit(1)
        elif args.mrt:
            zabbix.host_massremove(args.mrt[0], args.mrt[1])
        elif args.mrte != 'mrte':
            workbook = xlrd.open_workbook('zabbix_api.xlsx')
            for n_1 in xrange(workbook.sheets()[6].nrows):
                if n_1 == 0:
                    continue
                else:
                    hostgroup = workbook.sheets()[6].cell(n_1, 0).value
                    if hostgroup == '':
                        break
                    templateName = workbook.sheets()[6].cell(n_1, 1).value
                    if templateName == '':
                        break
                    try:
                        zabbix.host_massremove(hostgroup, templateName)
                    except Exception as e:
                        print u"Sheet3表第\033[041m%s\033[0m行数据异常\n\033[041m%s\033[0m" % (n_1 + 1, e)
                        sys.exit(1)
        #![08_创建主机组]
        elif args.cg:
            zabbix.hostGroup_create(args.cg[0])
        elif args.cge != 'cge':
            workbook = xlrd.open_workbook('zabbix_api.xlsx')
            for row in xrange(workbook.sheets()[7].nrows):
                if row == 0:
                    continue
                else:                    
                    hostgroup = workbook.sheets()[7].cell(row, 0).value
                    if hostgroup == '':
                        break
                    try:
                        zabbix.hostGroup_create(hostgroup)
                    except Exception as e:
                        print u"Sheet1表第\033[041m%s\033[0m行数据异常\n\033[041m%s\033[0m" % (row + 1, e)
                        sys.exit(1)
        elif args.dg:
            zabbix.hostGroup_delete(args.dg[0])
        elif args.dge != 'dge':
            workbook = xlrd.open_workbook('zabbix_api.xlsx')
            for row in xrange(workbook.sheets()[7].nrows):
                if row == 0:
                    continue
                else:
                    hostgroup = workbook.sheets()[7].cell(row, 0).value
                    if hostgroup == '':
                        break
                    try:
                        zabbix.hostGroup_delete(hostgroup)
                    except Exception as e:
                        print u"Sheet1表第\033[041m%s\033[0m行数据异常\n\033[041m%s\033[0m" % (row + 1, e)
                        sys.exit(1)
        #![09_为主机附加主机组]
        elif args.mag:
            zabbix.hostGroup_massadd(args.mag[0], args.mag[1])
        elif args.mage != 'mage':
            workbook = xlrd.open_workbook('zabbix_api.xlsx')
            for n_1 in xrange(workbook.sheets()[8].nrows):
                if n_1 == 0:
                    continue
                else:
                    hostName = workbook.sheets()[8].cell(n_1, 0).value
                    if hostName == '':
                        break
                    hostGroupName = workbook.sheets()[8].cell(n_1, 1).value
                    if hostGroupName == '':
                        break
                    try:
                        zabbix.hostGroup_massadd(hostName, hostGroupName)
                    except Exception as e:
                        print u"Sheet3表第\033[041m%s\033[0m行数据异常\n\033[041m%s\033[0m" % (n_1 + 1, e)
                        sys.exit(1)
        elif args.mrg:
            zabbix.hostGroup_massremove(args.mrt[0], args.mrt[1])
        elif args.mrge != 'mrge':
            workbook = xlrd.open_workbook('zabbix_api.xlsx')
            for n_1 in xrange(workbook.sheets()[8].nrows):
                if n_1 == 0:
                    continue
                else:
                    hostName = workbook.sheets()[8].cell(n_1, 0).value
                    if hostName == '':
                        break
                    hostGroupName = workbook.sheets()[8].cell(n_1, 1).value
                    if hostGroupName == '':
                        break
                    try:
                        zabbix.hostGroup_massremove(hostName, hostGroupName)
                    except Exception as e:
                        print u"Sheet3表第\033[041m%s\033[0m行数据异常\n\033[041m%s\033[0m" % (n_1 + 1, e)
                        sys.exit(1)
 


 

你可能感兴趣的:(运维工具)