User Tools

Site Tools


язык_программирования_python

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revision Previous revision
Next revision
Previous revision
язык_программирования_python [2025/04/08 13:53]
val [Дополнительные материалы]
язык_программирования_python [2025/05/27 11:53] (current)
val
Line 19: Line 19:
 </​code>​ </​code>​
  
 +
 +===== Интерактивная оболочка =====
 +<​code>​
 +(venv1) # pip install ipython
 +</​code>​
 ===== Web приложение ===== ===== Web приложение =====
  
Line 95: Line 100:
  
   * [[https://​dev.to/​francescoxx/​python-crud-rest-api-using-flask-sqlalchemy-postgres-docker-docker-compose-3kh4|Python CRUD Rest API using Flask, SQLAlchemy, Postgres, Docker, Docker Compose]]   * [[https://​dev.to/​francescoxx/​python-crud-rest-api-using-flask-sqlalchemy-postgres-docker-docker-compose-3kh4|Python CRUD Rest API using Flask, SQLAlchemy, Postgres, Docker, Docker Compose]]
 +
 +===== Zabbix API приложение =====
 +
 +  * [[https://​www.zabbix.com/​documentation/​current/​en/​manual/​api]]
 +  * [[https://​sbcode.net/​zabbix/​zabbix-api-python-example/​]]
 +  * [[https://​forum.checkmk.com/​t/​rest-api-python-question-how-to-use-variables-in-json-post-in-key-and-value/​34652]]
 +  ​
 +<​code>​
 +(venv1) server:~# pip install requests
 +
 +(venv1) server:~# cat zab_set_map_name.py
 +</​code><​code>​
 +#​!/​usr/​bin/​env python3
 +
 +import requests
 +import json
 +from sys import argv
 +
 +if len(argv) != 3 :
 +    print("​You must set argument!!!\nExample:​ python zab_set_map_name.py 2 \"ISP 1\""​)
 +    quit()
 +
 +MAPID = argv[1]
 +MAPNAME = argv[2]
 +
 +ZABBIX_API_URL = "​http://​127.0.0.1/​zabbix/​api_jsonrpc.php"​
 +UNAME = "​Admin"​
 +PWORD = "​zabbix"​
 +
 +print("​\nLogin user {} to Zabbiz API"​.format(UNAME))
 +r = requests.post(ZABBIX_API_URL,​
 +                  json={
 +                      "​jsonrpc":​ "​2.0",​
 +                      "​method":​ "​user.login",​
 +                      "​params":​ {
 +                          "​username":​ UNAME,
 +                          "​password":​ PWORD},
 +                      "​id":​ 1
 +                  })
 +
 +print(json.dumps(r.json(),​ indent=4, sort_keys=True))
 +
 +AUTHTOKEN = r.json()["​result"​]
 +
 +#​print("​Rename Map with ID", MAPID, "​to",​ MAPNAME)
 +print(f"​Rename Map with ID {MAPID} to {MAPNAME}"​)
 +
 +r = requests.post(ZABBIX_API_URL,​
 +                  headers={'​Authorization':​ '​Bearer ' + AUTHTOKEN},
 +                  json={
 +                    "​jsonrpc":​ "​2.0",​
 +                    "​method":​ "​map.update",​
 +                    "​params":​ {
 +                        "​sysmapid":​ MAPID,
 +                        "​name":​ MAPNAME
 +                    },
 +                    "​id":​ 2
 +                  })
 +
 +print(json.dumps(r.json(),​ indent=4, sort_keys=True))
 +
 +print("​\nLogout user")
 +r = requests.post(ZABBIX_API_URL,​
 +                  headers={'​Authorization':​ '​Bearer ' + AUTHTOKEN},
 +                  json={
 +                      "​jsonrpc":​ "​2.0",​
 +                      "​method":​ "​user.logout",​
 +                      "​params":​ {},
 +                      "​id":​ 2,
 +                  })
 +
 +print(json.dumps(r.json(),​ indent=4, sort_keys=True))
 +</​code><​code>​
 +(venv1) server:~# chmod +x zab_set_map_name.py
 +
 +(venv1) server:~# ./​zab_set_map_name.py 2 "ISP 1"
 +</​code>​
 +
 +===== Zabbix LLD приложение =====
 +
 +  * [[https://​www.geeksforgeeks.org/​python-find-dictionary-matching-value-in-list/​]]
 +  * [[https://​docs-python.ru/​tutorial/​vstroennye-funktsii-interpretatora-python/​funktsija-next/​]]
 +<​code>​
 +gate# apt install python3-xmltodict/​stable
 +
 +gate# cat /​etc/​zabbix/​dhcp-pools.py
 +</​code><​code>​
 +#​!/​usr/​bin/​env python3
 +
 +# Example usage:
 +# ./​dhcp-pools.py
 +# ./​dhcp-pools.py LAN1 defined|used
 +
 +from sys import argv
 +import subprocess, xmltodict, json
 +
 +p = subprocess.Popen("/​usr/​bin/​dhcpd-pools -f x", stdout=subprocess.PIPE,​ shell=True)
 +(output, err) = p.communicate()
 +p_status = p.wait()
 +
 +o = xmltodict.parse(output)
 +
 +if len(argv)==1:​
 +  r=[]
 +  for i in o['​dhcpstatus'​]['​shared-network'​]:​
 +    s={}
 +    s["​{#​POOLNAME}"​]=i['​location'​]
 +    r.insert(1,​s)
 +  print(json.dumps(r))
 +else:
 +  LANNAME=argv[1]
 +  USDEF=argv[2]
 +  res = next((sub for sub in o['​dhcpstatus'​]['​shared-network'​] if sub['​location'​] == LANNAME), None)
 +  print(res[USDEF])
 +</​code>​
  
 ===== Дополнительные материалы ===== ===== Дополнительные материалы =====
 +
 +  * [[https://​pypi.org/​project/​ansible-output-parser/​]]
 +  * [[https://​www.cyberciti.biz/​faq/​python-run-external-command-and-get-output/​]]
  
 ==== Доступ к каталогу по http ==== ==== Доступ к каталогу по http ====
Line 106: Line 229:
 </​code>​ </​code>​
  
 +==== Черновик ====
  
язык_программирования_python.1744109632.txt.gz · Last modified: 2025/04/08 13:53 by val