![]() |
loop printing twice - Printable Version +- Python Forum (https://python-forum.io) +-- Forum: Python Coding (https://python-forum.io/forum-7.html) +--- Forum: General Coding Help (https://python-forum.io/forum-8.html) +--- Thread: loop printing twice (/thread-20722.html) |
loop printing twice - anna - Aug-27-2019 Hi All, below is the my code, however while I am checking List value in another file, post matching its printing twice. from ciscoconfparse import CiscoConfParse from ciscoconfparse.ccp_util import IPv4Obj import netaddr import mysql.connector import re def dslam_ip_fromdb(): global mydb global dslamip_list dslamip_list = [] try: mydb = mysql.connector.connect(host="localhost", user="admin", passwd="nx63299", database="device") if mydb.is_connected(): mycursor = mydb.cursor() sql = "SELECT * FROM host_details WHERE access_group='TTML'" try: # Execute the SQL command mycursor.execute(sql) # Fetch all the rows in a list of lists. results = mycursor.fetchall() for row in results: ip_addr = row[6] dslamip_list.append(ip_addr) except: print("Error: unable to fecth data") except Error as e: print("Error reading data from MySQL table", e) finally: if (mydb.is_connected()): mydb.close() mycursor.close() print("MySQL connection is closed") with open('dslamips.txt') as ipdatafile: for sr_no, line in enumerate(ipdatafile, start=1): for ips in dslamip_list: if ips in line: print("{} {}".format(sr_no,line)) if __name__ == "__main__": interface_details = [] # the result dictionary result = { "interfaces": {} } global sub_interface sr_no = 0 conf_file = "E320.conf" confparse = CiscoConfParse(conf_file) global_obj = confparse.find_objects(r'^hostname')[0] sysname = global_obj.re_match_typed(r'^hostname\s+(\S+)', default='').strip('"') interface_cmds = confparse.find_objects(r"^interface ") for interface_cmd in interface_cmds: intf_name = interface_cmd.text[len("interface "):] result["interfaces"][intf_name] = {} result["interfaces"][intf_name]["svlan"] = "svlan_not_set" result["interfaces"][intf_name]["cvlan"] = "cvlan_not_set" for cmd in interface_cmd.re_search_children(r"^ svlan "): result["interfaces"][intf_name]["svlan"] = cmd.text.strip()[len(" svlan id"):].split(' ')[0] result["interfaces"][intf_name]["cvlan"] = cmd.text.strip()[len(" svlan id"):].split(' ')[1] result["interfaces"][intf_name]["status"] = "Active" for cmd in interface_cmd.re_search_children(r"^ shutdown"): result["interfaces"][intf_name]["status"] = "Shutdown" ip_static_routes_conf= confparse.find_blocks(r"^ip route ") with open('dslamips.txt','w') as routefile: for route in ip_static_routes_conf: if 'GigabitEthernet' in route: routefile.write(route+'\n') with open('svlan_cvlan.txt','w') as vlanfile: for interface in result["interfaces"].items(): if 'Shutdown' in interface[1].values() or 'lag' in interface[0]: continue if 'gigabitEthernet' in interface[0]: data = interface[0]+";",";".join(interface[1].values()) data_to_write = data[0] + data[1] vlanfile.write(data_to_write+"\n") else: continue #Function calling dslam_ip_fromdb()sample output
RE: loop printing twice - anna - Sep-04-2019 issue found in below code, now its resolved. with open('dslamips.txt') as ipdatafile: for sr_no, line in enumerate(ipdatafile, start=1): for ips in dslamip_list: to_bematch_ip = line.strip().split(' ')[2] if ips == to_bematch_ip: dslamInterface = "gigabitEthernet "+(line.strip().split(' ')[-1].strip()[len("GigabitEthernet"):]) insert_DSLAM_dataInDB(dslamInterface,ips) #print("ip={} {} {}".format(ips,sr_no,line)) |