• 60%的人不懂Python中的多线程,本文教你


     

    python 里有一个 threading 模块,其中提供了一个函数:

    threading.Thread(target=function, args=(), kwargs={})

    function 是开发者定义的线程函数,

    args 是传递给线程函数的参数,必须是tuple类型,

    kwargs 是可选参数,字典类型。

    调用 threading.Thread 之后,会创建一个新的线程,参数 target 指定线程将要运行的函数,args 和 kwargs 则指定函数的参数来执行 

    function 函数。

    改写一下前面的代码,将抓取的部分放在一个函数中:

    def get_weather(city):
        req = requests.get('http://wthrcdn.etouch.cn/weather_mini?city=%s' % city)
        dic_city = req.json()
    
        city_data = dic_city.get('data')  # 没有’data‘的话返回 []
        print(city_data.get('city'))    if city_data:
            city_forecast = city_data['forecast'][0]  # 下面的都可以换成'get'方法
            print(city_forecast.get('date'))
            print(city_forecast.get('high'))
            print(city_forecast.get('low'))
            print(city_forecast.get('type'))    else:
            print('未获得')
        print()

    之后,程序采用了三个循环,在第一个循环中,针对每一个城市,都创建了一个新线程,并将线程加入到一个列表中,用于之后的启动。

    threads = []
    cities = ['北京', '南京', '上海', '深圳', '广州', '杭州', '苏州', '天津', '西安', '成都']
    files = range(len(cities))for i in files:  # 创建线程
        t = threading.Thread(target=get_weather, args=(cities[i],))
        threads.append(t)

    在第二个循环中,start 正式开启子线程;

    for i in files:
        threads[i].start()

    在第三个循环中,join 用来同步数据,主线程运行到这一步,将会停下来等待子线程运行完毕。没有这句,主线程则会忽略子线程,运行

    完自己的代码后结束程序。

    for i in files:
        threads[i].join()

    最后注意:光理论是不够的。这里顺便免费送大家一套2020最新python入门到高级项目实战视频教程,可以去小编的Python交流.裙 :七衣衣九七七巴而五(数字的谐音)转换下可以找到了,还可以跟老司机交流讨教!
    本文的文字及图片来源于网络加上自己的想法,仅供学习、交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理。

  • 相关阅读:
    2.Liunx 系统设置
    1.Liunx 文件管理
    Liunx 更新环境时用到的命令
    解决SSH Secure Shell 连接Liunx 有乱码情况。
    JMeter 性能测试基本过程及示例(4)
    在 macOS 中怎样获取当前文件夹的路径?
    Mac环境安装启动jmeter
    StringUtils工具类常用方法汇总1(判空、转换、移除、替换、反转)
    Json与Gson
    Quartz的基本使用之入门(2.3.0版本)
  • 原文地址:https://www.cnblogs.com/chengxuyuanaa/p/13066361.html
Copyright © 2020-2023  润新知