day19-HTTP协议和多线程基础

一.http请求

第三方库:requests提供了所有和http请求相关的函数

1.get请求

get(url, params=None) - 发送请求获取服务器返回的响应
url - 请求地址(字符串)
params - 请求参数(字典)

1)方法1:(既适用于get也适用于post)

url = 'https://www.apiopen.top/satinApi'
params = {'type': 1, 'page': 2}
response = requests.get(url, params)

2)方法2:(只能用于get)

url = 'https://www.apiopen.top/satinApi?type=1&page=1'
response = requests.get(url)

2.获取请求结果

1)响应头

print(response.headers)

2)响应体(数据)
a.获取二进制对应的原数据(当数据本身是图片、压缩包、视频等文件时)

content = response.content
print(content)

b.获取字符串类型的数据

text = response.text
print(text)

c.获取json数据(拿到的json数据会自动转换成python对应的数据)

json = response.json()
print(json, type(json))

import requests


url = 'https://www.apiopen.top/satinApi'
params = {'type': 1, 'page': 2}
response = requests.get(url, params)
print(response.headers)
content = response.content
print(content)
text = response.text
print(text)
json = response.json()
print(json)

二.多线程基础

import threading
from datetime import datetime
from time import sleep
线程
每个进程中默认都有一条线程,这个线程叫主线程,其他线程都叫子线程
threading模块中Thread的对象就是线程对象,当程序中需要子线程就创建Thread类的对象

1.方法1

1)创建线程对象

threading.Thread(target=None, args=()) - 创建并且返回一个子线程对象
target - 函数类型(function),在线程启动的时候这个函数会在子线程中执行
args - 元组,元组中的元素就是target对应的函数在子线程中调用的时候传的实参

2)启动线程

线程对象.start() - 让线程去执行线程中的任务
执行过程 = target(*args)
查看当前运行线程:threading.current_thread()

def download(film_name: str):
    print('开始下载{}:{}'.format(film_name, datetime.now()))
    sleep(5)
    print('{}下载结束:{}'.format(film_name, datetime.now()))


t1 = threading.Thread(target=download, args=('楚门的世界',))
t2 = threading.Thread(target=download, args=('天佑美利坚',))
t3 = threading.Thread(target=download, args=('林中小屋',))
t1.start()
t2.start()
t3.start()

2.方法2:

1)声明一个类继承Thread
2)实现类中的run方法,这个方法中的代码就是需要在子线程中执行的代码
3)需要子线程的时候就创建自己声明类的对象,并且不需要任何参数
注意:
a.不能在主线程中通过'对象.run()'调用进程,否则不会进入子线程,必须使用'对象.start'调用
b.线程中的任务执行完成后线程就结束,进程中的所有线程都结束后进程才结束

from threading import *
from datetime import datetime
from time import sleep


class DownloadThread(Thread):
    def __init__(self, film_name):
        super().__init__()
        self.film_name = film_name

    def run(self):
        print('开始下载{}:{}'.format(self.film_name, datetime.now()))
        print(current_thread())
        sleep(5)
        print('{}下载结束:{}'.format(self.film_name, datetime.now()))


if __name__ == '__main__':
    t1 = DownloadThread('惊声尖笑')
    t1.start()

三.join方法

1.join的用法

线程对象.join() - 当前线程对象任务执行完成后才能去执行后面的代码块
代码块

from threading import *
from datetime import datetime
from time import *
from random import randint


def download(film_name):
    print('开始下载%s: %s' % (film_name, datetime.now()))
    sleep(randint(3, 7))
    print('%s下载结束: %s' % (film_name, datetime.now()))


if __name__ == '__main__':
    t1 = Thread(target=download, args=('film1',))
    t2 = Thread(target=download, args=('film2',))
    t3 = Thread(target=download, args=('film3',))
    t1.start()
    t2.start()
    t3.start()
    # 情况1:三个电影下载完成才打印下载完成
    t1.join()
    t2.join()
    t3.join()
    print('下载完成!')
    # 情况2:电影1下载完成后电影2/3开始下载
    t1.start()
    t1.join()
    t2.start()
    t3.start()
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容