Python 實現(xiàn)域名解析為ip的方法
更新時間:2019年02月14日 15:09:45 作者:黑面狐
今天小編就為大家分享一篇Python 實現(xiàn)域名解析為ip的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
今天得了一批域名,需要把域名解析成ip
因為量比較大所以采用了多進程和隊列的方式
from multiprocessing import Process,Queue,Pool import socket import multiprocessing import os #寫入文件 def write(q,lock,filename): while not q.empty(): url = q.get() print (url) try: ip = socket.gethostbyname(url) except: ip = "unknow" print (ip) with open(filename,'a+') as f: lock.acquire() #加鎖防止多個進程寫入會混亂 try: f.write(url + " " + ip + "\n") finally: lock.release() #添加到隊列 def readurl(q,n): with open(str(n)+'.txt','r') as f: lines = f.readlines() for line in lines: q.put(line.strip()) return q #根據進程進行拆分txt def multi(urllist,n): with open(urllist,'r') as f: lines = f.readlines() line = int(len(lines)/n) print (line) for m in range(0,n): with open(str(m)+'.txt','a+') as f1: for i in range(line*m,line*(m+1)): f1.write(lines[i]) #刪除拆分的txt文件 def remove(n): for i in range(0,n): os.remove(str(i)+'.txt') print ("######清除臨時文件######") if __name__ == "__main__": manager = multiprocessing.Manager() q = manager.Queue() lock = manager.Lock() m = 5 #設置掃描進程數(shù) urllist = "url.txt" #待解析的url filename = "test.txt" #結果保存的文件名 multi(urllist,m) p = Pool(m) for i in range(m): p.apply_async(write,args=(readurl(q,i),lock,filename)) p.close() p.join() remove(m) print ("#######全部文件采集完成########")
以上這篇Python 實現(xiàn)域名解析為ip的方法就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
Python實現(xiàn)搜索Google Scholar論文信息的示例代碼
這篇文章主要為大家詳細介紹了如何利用Python實現(xiàn)搜索Google Scholar論文信息的功能,文中的示例代碼講解詳細,需要的可以參考一下2023-03-03selenium + python 獲取table數(shù)據的示例講解
今天小編就為大家分享一篇selenium + python 獲取table數(shù)據的示例講解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-10-10