http协议和多线程基础
一.http请求
import requests
python中有一个第三方库叫'requests'中提供了所有和http请求相关的函数
# 1.get请求
# get(url, params = None) - 发送请求获取服务器返回的响应
#
# url:请求地址
# params:请求参数,字典
# 方法一:(既适用于get也适用于post)
url = 'https://www.apiopen.top/satinApi'
params = {'type':1, 'page':2}
response = requests.get(url, params)
print(response)
# 方法二:只能用于get请求
url = 'https://www.apiopen.top//satinApi?type=1&page=1'
# response = requests.get(url)
# print(response)
# 2.获取请求结果
# 1)响应头
print(response.headers)
# 2)响应体(数据)
# a.获取二进制对应的原数据(数据本身是图片、压缩文件、视频等文件信息)
content = response.content
print(type(content))
# b.获取字符串类型的数据
text = response.text
print(type(text))
# c.获取json数据(json转换成python对应的数据)
json = response.json()
print(type(json))
print(json)
二·多线程基础
import threading
from datetime import datetime
from time import sleep
# 1.线程
# 每个进程默认都有一条线程,这个线程主线程。其他线程叫子线程。
print(threading.current_thread())
# threading模块中Thread的对象就是线程对象,当程序需要子线程就创建Thread类的对象。
def download(film_name):
print('开始下载%s:%s'%(film_name, datetime.now()))
print(film_name, threading.current_thread())
sleep(5)
print('%s下载结束:%s'%(film_name, datetime.now()))
if __name__ == '__main__':
# download('魔童降世')
# download('扫毒2')
# download('砰然心动')
# 1.创建线程对象
# Thread(target = None, args= ()) - 创建并且返回一个子线程对象
# target - '函数类型(function),在线程启动的时候这个函数会在子线程中执行'
# args - 元祖,元祖中的元素就是target对应的元素就是在子线程中调用的时候传的实参
t1 = threading.Thread(target=download, args=('魔童降世',))
t2 = threading.Thread(target=download, args=('扫毒2',))
t3 = threading.Thread(target=download, args=('怦然心动',))
# 2.启动线程
# 线程对象.start() - 让线程去执行线程中的任务
t1.start()
t2.start()
t3.start()
三·多线程基础2
程序结束
线程中的任务执行完成线程结束;程序出现异常结束的是线程不是进程
进程中的所有线程都结束进程才结束
# 1.声明一个类继承Thread
# 2.实现类中的run方法,这个方法中的的代码就是需要在子线程中执行的代码
# 3.需要子线程的时候就创建自己声明的类的对象,并且不需要任何参数
class DownLoadThread(Thread):
def __init__(self, file_name):
super().__init__()
self.file_name = file_name
def run(self) -> None:
print('开始下载%s:%s' % (self.file_name, datetime.now()))
print(self.file_name, current_thread())
sleep(5)
print('%s下载结束:%s' % (self.file_name, datetime.now()))
if __name__ == '__main__':
t1 = DownLoadThread('魔童降世')
print(t1.file_name)
t1.start()
t2 = DownLoadThread('扫毒2')
t2.start()
四·join
def Download(file_name):
print('开始下载%s:%s'%(file_name, datetime.now()))
sleep(randint(3,7))
print('%s下载结束:%s'%(file_name, datetime.now()))
if __name__ == '__main__':
# 1.join的用法
# 线程对象.join() - 当前线程任务执行完成后才能去执行后面的代码
t1 = Thread(target=Download, args=('魔童降世',))
t2 = Thread(target=Download, args=('扫毒2',))
t3 = Thread(target=Download, args=('怦然心动',))
# t1.start()
# t2.start()
# t3.start()
# 三个电影都下载完成才执行'下载完成'
# t1.join()
# t2.join()
# t3.join()
# print('下载完成!')
# 电影1下载完成后才开始下载电影2和电影3
t1.start()
t1.join()
t2.start()
t3.start()