1._thread.start_new_thread(了解)
import threading import time import _thread def job(): print("这是一个需要执行的任务。。。。。") print("当前线程的个数:", threading.active_count() ) print("当前线程的信息:", threading.current_thread()) time.sleep(100) if __name__ == '__main__': # 创建多线程时, 需要制定该线程执行的任务 _thread.start_new_thread(job, ()) _thread.start_new_thread(job, ()) job()
本文来源gaodai$ma#com搞$$代**码)网@2.threading.Thread
import threading import time def job(): print("这是一个需要执行的任务。。。。。") print("当前线程的个数:", threading.active_count() ) time.sleep(1) print("当前线程的信息:", threading.current_thread()) if __name__ == '__main__': # 创建多线程时, 需要制定该线程执行的任务.name线程名字 target目标函数名 t1 = threading.Thread(target=job,name='job1') t2 = threading.Thread(target=job,name='job2') t1.start() t2.start() print(threading.active_count()) print("程序执行结束.....")
输出:
这是一个需要执行的任务。。。。。
当前线程的个数: 3
这是一个需要执行的任务。。。。。
3
程序执行结束…..
当前线程的个数: 3
当前线程的信息: <Thread(job1, started 140416648140544)>
当前线程的信息: <Thread(job2, started 140416639747840)>
出现的问题: 主线程执行结束, 但是子线程还在运行。
join()方法可以等待所有的子线程执行结束之后, 再执行主线程。
import threading import time def job(): print("这是一个需要执行的任务。。。。。") print("当前线程的个数:", threading.active_count() ) print("当前线程的信息:", threading.current_thread()) time.sleep(1) if __name__ == '__main__': # 创建多线程时, 需要制定该线程执行的任务.name线程名字 target目标函数名 t1 = threading.Thread(target=job,name='job1') t2 = threading.Thread(target=job,name='job2') t1.start() t2.start() print(threading.active_count()) # 出现的问题: 主线程执行结束, 但是子线程还在运行。 # 等待所有的子线程执行结束之后, 再执行主线程 t1.join() t2.join() print("程序执行结束.....")
之前写过一个简单爬虫的实验,现在希望获取十个ip的城市和国家
-不使用多线程
import time from urllib.request import urlopen # 记录时间的装饰器 def timeit(f): def wrapper(*args, **kwargs): start_time = time.time() res = f(*args, **kwargs) end_time = time.time() print("%s函数运行时间:%.2f" % (f.__name__, end_time - start_time)) return res return wrapper def get_addr(ip): url = "http://ip-api.com/json/%s" % (ip) urlObj = urlopen(url) # 服务端返回的页面信息, 此处为字符串类型 pageContent = urlObj.read().decode('utf-8') # 2. 处理Json数据 import json # 解码: 将json数据格式解码为python可以识别的对象; dict_data = json.loads(pageContent) print(""" %s 所在城市: %s 所在国家: %s """ % (ip, dict_data['city'], dict_data['country'])) @timeit def main(): ips = ['12.13.14.%s' % (i + 1) for i in range(10)] for ip in ips: get_addr(ip) if __name__ == '__main__': main()