print('[+] | %s | %s | %s | %s | %s | %s | %s | %s | %s |' % ( addr_port,addr, portid, state, protocol, addrtype, reason, reason_ttl, scan_endtime))
时间: 2023-08-21 22:22:55 浏览: 66
这行代码的作用是将获取到的 Masscan 扫描结果输出到控制台。具体来说,它使用了格式化字符串的方式,将获取到的扫描结果按照一定的格式输出到控制台。其中 %s 是格式化字符串中的占位符,后面紧跟着 % 操作符和对应的变量,表示将该变量的值插入到格式化字符串的对应位置。整个字符串中的 | 符号和空格是为了格式化输出的结果,让输出结果更加美观易读。
相关问题
def convert_masscan_report(xml_path, xls_path): DOMTree = xml.dom.minidom.parse(xml_path) data = DOMTree.documentElement nodelist = data.getElementsByTagName('host') ip_info = {} for node in nodelist: scan_endtime = node.getAttribute('endtime') scan_endtime = time.strftime('%Y-%m-%d %H:%M:%S', time.localtime(int(scan_endtime))) address_node = node.getElementsByTagName('address') addrtype = address_node[0].getAttribute('addrtype') addr = address_node[0].getAttribute('addr') port_node = node.getElementsByTagName('port') ip_prefix = addr.split(".")[0] + "." + addr.split(".")[1] + "." + addr.split(".")[2] if ip_prefix not in ip_info: ip_info[ip_prefix] = {} for port in port_node: if addr in ip_info[ip_prefix]: ip_info[ip_prefix][addr][1] = ip_info[ip_prefix][addr][1] + "," + portid continue protocol = port.getAttribute('protocol') portid = port.getAttribute('portid') state_element = port.getElementsByTagName('state') state = state_element[0].getAttribute('state') reason = state_element[0].getAttribute('reason') reason_ttl = state_element[0].getAttribute('reason_ttl') print('[+] | %s | %s | %s | %s | %s | %s | %s | %s |' % ( addr, portid, state, protocol, addrtype, reason, reason_ttl, scan_endtime)) scan_info = [addr, portid, state, protocol, addrtype, reason, reason_ttl, scan_endtime] ip_info[ip_prefix][addr] = scan_info workbook = xlsxwriter.Workbook(xls_path) for sheet_name, sheet_value in ip_info.items(): worksheet = workbook.add_worksheet(sheet_name) worksheet.autofilter("A1:H1") # 设置过滤 worksheet.freeze_panes(1, 0) # 冻结窗格 worksheet.lastrow = 0 summary_header = ["addr", "port", "state", "protocol", "addrtype", "reason", "reason_ttl", "scan_endtime"] for idx, item in enumerate(summary_header): worksheet.write(0, idx, item, workbook.add_format({"bold": True})) worksheet.lastrow += 1 for addr, addr_info in sheet_value.items(): for i in range(0, len(addr_info)): worksheet.write(worksheet.lastrow, i, addr_info[i]) worksheet.lastrow += 1 workbook.close()
这段代码的功能是将 Masscan 扫描结果的 XML 格式转换成 Excel 格式。具体实现的过程是:首先解析 XML 文件,然后遍历 XML 中的每个 host 节点,获取其中的 IP 地址,端口号等信息。将 IP 地址按照前三个段进行分组,最终将结果写入到 Excel 文件中,每个 IP 段对应一个 Excel Sheet,每个 Sheet 中包含了该 IP 段下的所有 IP 地址和对应的扫描结果。
# 用字符串来存储最原始的球员信息 player_infos = """Carmelo Anthony,Portland Trail Blazers,SF; Anthony Davis,Los Angeles Lakers,PF; LeBron James,Los Angeles Lakers,SF; Kevin Durant,Brooklyn Nets,SF; James Harden,Brooklyn Nets,PG; Kyrie Irving,Brooklyn Nets,SG; Damian Lillard,Portland Trail Blazers,PG""" # 将原始字符串通过split方法以分号来切割,得到一个列表,并赋值给一个变量 player_infos_list = player_infos.split(';') # 创建一个空字典,用于存储{球队:球员信息列表} team_dict_ = {} # 遍历刚才切割得到的列表,每一个元素都是一个球员信息的字符串 for player_str in player_infos_list: # 将球员字符串通过逗号进行再次切割,得到一个列表,列表里面包含了一个球员的三个特征 player = player_str.split(',') # 获取球员姓名 player_name = player[0].strip() # 获取球员的球队 player_team = player[1].strip() # 获取球员的位置 player_position = player[2].strip() # 将球员信息构建为一个字典 player_info_dic = {"name": player_name, "team": player_team, "position": player_position} # 首先判断球队在不在定义的team_dict里面,如果不在,就为team_dict增加一对键值对,键为球队,值为一个空列表 if player_team not in team_dict: team_dict[player_team] = [] # 然后将球员信息追加到这个列表里面,当循环走完,team_dict里面就存储了所有的球队和球员信息 team_dict[player_team].append(player_info_dic) # team_dict里面获取所有的球队信息,并拼成一个字符串 teams = '|'.join(list(team_dict.keys())) # 通过input函数让用户输入需要查询的球队 team = input("请输入你要查询的球队%s:" % teams) # 利用字典的键索引拿到该球队所有的球员信息列表 team_info = team_dict[team] # 打印表头 print('+' + '-' * 67 + '+') # 这里使用了字符串的center方法和字符串的格式化表达 print("|%s|%s|%s|" % ( 'name'.center(25), 'team'.center(30), 'position'.center(10) )) print('+' + '-' * 67 + '+') # 遍历球员信息列表,格式化打印每个球员信息 for player_info in team_info: print("|%s|%s|%s|" % ( player_info['name'].center(25), player_info['team'].center(30), player_info['position'].center(10), )) print('+' + '-' * 67 + '+')
这段代码是一个Python程序,用于处理篮球球员信息。它首先将一个包含多个球员信息的字符串切割成列表,然后再将每个球员信息切割成三个特征:姓名、所在球队和位置。接着,它将每个球员信息构建成一个字典,并将字典追加到对应球队的列表里面,最终得到一个以球队为键、球员信息列表为值的字典。程序会提示用户输入需要查询的球队,并根据用户输入的球队获取该球队所有的球员信息列表。最后,程序会打印表头和每个球员的信息。
阅读全文
相关推荐

















