python中有一个第三方库叫requests,提供了所有与http请求的相关函数
get请求
'''
get(url, param=None) -- 发送请求获取服务器返回的响应
url -- 请求地址。字符串
params -- 请求参数,字典
'''
import requests
方法1,试用post,get两个
url = 'https://www.cnblogs.com/1fengchen1/p/9506985.html'
params = {'type':1,'page':2}
res = requests.get(url, params) #get自动将url和param连接
print(res.status_code)
方法2,只试用于get
res = requests.get('https://www.cnblogs.com/1fengchen1/p/9506985.html?type=1&page=2')
获取请求结果
1)响应头
print(res.headers)
2)响应体(数据)
a,获取二进制对应的原数据(数据本身是图片,视频等二进制数据)
content = res.content
print(type(content))
b.获取字符串类型的数据
text = res.text
print(type(text))
c.获取json数据(json转换成python对应的数据)
json1 = res.json()
print(type(json1))
print(json1)
线程
'''
每个线程中默认都有一条线程,这个线程叫主线程,其他线程叫子线程
threading模块中的Tread的对象就是线程对象,当程序中需要子线程就创建Tread的对象
'''
import threading
from _datetime import datetime
import time
def downloads(film_name):
print('开始下载%s:%s'%(film_name, datetime.now()))
print(threading.current_thread())
time.sleep(5)
print('%s下载结束:%s'%(film_name, datetime.now()))
if _ _ name _ _ == '_ _ main _ _':
# downloads('西游')
# downloads('东游')
# downloads('北游')
#1.创建线程对象
'''
t1 = Tread(target=None, args=()) -- 创建并且返回一个子线程对象
target - 函数类型(function),在启动线程的时候这个函数会在子线程中执行
args - 元组,元组中的元素就是target对应的函数在子线程中调用的时候传的实参
'''
t1 = threading.Thread(target=downloads, args=('东游',))
t2 = threading.Thread(target=downloads, args=('西游',))
t3 = threading.Thread(target=downloads, args=('北游',))
# print(threading.current_thread())
#启动线程
'''
线程对象.start() -- 让线程去执行线程中的任务
target(*args)
'''
t1.start()
t2.start()
t3.start()
程序结束
'''
线程中的任务执行完成线程就结束,程序出现异常结束的是线程,进程不会结束,进程中的所有线程都结束,进程才结束
'''
from threading import *
from datetime import datetime
import time
1.声明一个类继承Thread
2.实现类中的run方法,这个方法中的代码就是需要在子线程中执行的代码
需要子线程的时候就创建自己声明的类的对象,并且不需要任何参数
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(current_thread())
time.sleep(5)
print('%s下载结束:%s'%(self.file_name, datetime.now()))
if name == 'main':
t1 = DownloadThread('东游')
t2 = DownloadThread('西游')
t1.start()
t2.start()
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 _ _':
1.join的用法
'''
线程对象.join() - 当前线程对象任务执行完成后才能去执行后面的代码
'''
t1 = Thread(target=download, args=('东游',))
t2 = Thread(target=download, args=('西游',))
t3 = Thread(target=download, args=('北游',))
t1.start()
t2.start()
t3.start()
t1.join()
t2.join()
t3.join()
print('下载完成')