day19-总结

import requests

python中有一个第三方库‘requests’中提供了所有和http请求相关的函数

1.get请求

get(url, params=None) - 发送请求获取服务器返回的响应

url - 请求地址
params - 请求参数,字典

方法1:适用于get和post,只需要将requests.后面改为post (接口是post或get的前提下)
url = 'http://ww.apiopen.top/satinApi'
params = {'type': 1, 'page': 2}
response = requests.get(url, params)
print(response)
方法2:只适用于get
url = 'http://ww.apiopen.top/satinApi?type=1&page=1'
response = requests.get(url)
print(response)
2.获取请求结果

1)响应头
{'Server': 'nginx', 'Date': 'Thu, 15 Aug 2019 03:41:29 GMT', 'Content-Type': 'text/html', 'Content-Length': '162', 'Connection': 'keep-alive'}

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))

多线程基础

import threading

from time import sleep

from datetime import datetime

1.线程

每个进程中默认都有一个线程,这个线程叫主线程。其它线程叫子线程
threading模块中Thread的对象就是线程对象,当程序中需要子线程就创建Thread类的对象

def download(film_name):
    print('开始下载%s:%s' % (film_name, datetime.now()))
    print(threading.current_thread())
    sleep(5)
    print('%s下载结束:%s' % (film_name, datetime.now()))


if __name__ == '__main__':

    download('ss')
    download('aa')
    download('bb')

    # 1.创建线程对象
    """
    Thread(target=None, args=()) - 创建并返回一个子线程对象
    target - 函数类型(function),这个函数在线程启动的时候会在子线程中执行
    args - 元祖(tuple),给target中的函数传参的实参
    """
    t1 = threading.Thread(target=download, args=('cxx',))
    t2 = threading.Thread(target=download, args=('cxk',))
    t3 = threading.Thread(target=download, args=('das',))
    print(threading.current_thread())
    # 2.启动线程
    """
    线程对象.start() - 让线程取执行线程中的任务
    """
    t1.start()
    t2.start()
    t3.start()

from threading import *

from time import sleep

from datetime import datetime

程序结束

线程中的任务执行完成线程就结束;程序出现异常结束的是异常的线程,不是进程(其它线程还会进行)
进程中的所有线程结束进程才结束

1.声明一个类继承Thread
2.实现类中的run方法,这个方法中的代码就是需要在子线程中执行的代码
3.需要子线程的时候就创建自己声明类的线程对象,不需要传参
class DownloadThread(Thread):

    def __init__(self, film_name):
        super().__init__()
        self.film_name = film_name

    def run(self) -> None:
        print(current_thread())
        print('开始下载%s:%s' % (self.film_name, datetime.now()))
        # print(current_thread())
        sleep(5)
        print('%s下载结束:%s' % (self.film_name, datetime.now()))


if __name__ == '__main__':

    t1 = DownloadThread('jsxc')
    t2 = DownloadThread('kjfd')
    t1.start()
    t2.start()
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • python中有一个第三方库叫requests,提供了所有与http请求的相关函数 get请求 '''get(ur...
    茅人阅读 125评论 0 0
  • 线程 操作系统线程理论 线程概念的引入背景 进程 之前我们已经了解了操作系统中进程的概念,程序并不能单独运行,只有...
    go以恒阅读 1,777评论 0 6
  • 网络编程 1.socket socket又叫套接字,指的是网络通信的两端,分别是服务器和客户端 socket编程指...
    灬小鱼儿zzZ阅读 201评论 0 0
  • """author = Zard"""import threadingfrom time import sleep...
    Zard泉水阅读 123评论 0 1
  • 1. python中有一个第三方库叫'requests'中提供了所有和http请求相关的函数 1.1 get请求 ...
    酒煮灬核弹头阅读 135评论 0 0

友情链接更多精彩内容