• python自(2)切片 字典 遍历删除添加修改查询定义函数函数返回值作用域序列化异常报错urllib使用一个类型六个方法下载 视频音频图片


    切片

    1. # # 切片
    2. # s = 'hello word'
    3. # # 下标索引为0
    4. # print(s[0]) #h
    5. # # 左闭右开 (左是下标开始的,右是几个索引值)例如从0开始算 4个索引值
    6. # print(s[0:4]) #hell
    7. # # 更改起始值的开始位置
    8. # print(s[1:]) #ello word
    9. # # 下标结束位置
    10. # print(s[:5]) #hello
    11. # #从下标为0的位匿开始到下标为6的位置结束每次增长2个长度
    12. # print(s[0:6:2]) #hlo

    字典 遍历  删除 添加  修改 查询

    1. # 字典查询
    2. # preson = {'name':'周阿狗' ,'age':18}
    3. # # 查询方式
    4. # print(preson['name']) #周阿狗 直接打印name的值
    5. # print(preson.get('age')) #18 可以使用get获取值
    6. # # print(preson["sex"]) #报错 因为没有sex KeyError: 'sex'
    7. # 字典修改 preson['name'] 选的有的数据进行修改 没有的就是添加 有的就是修改
    8. # preson = {'name':'周阿狗' ,'age':18}
    9. # print(preson) #{'name': '周阿狗', 'age': 18}
    10. # preson['name'] = '张三'
    11. # print(preson) #{'name': '张三', 'age': 18}
    12. # # 字典添加 preson['sex']没有的进行添加 没有的就是添加 有的就是修改
    13. # preson = {'name':'周阿狗' ,'age':18}
    14. # print(preson) #{'name': '周阿狗', 'age': 18}
    15. # preson['sex'] = '男'
    16. # print(preson) #{'name': '周阿狗', 'age': 18, 'sex': '男'}
    17. # preson['name'] = '张三'
    18. # print(preson) #{'name': '张三', 'age': 18, 'sex': '男'}
    19. # # 字典删除 del不可以删除对象(preson) clear 删除全部但是保留对象(括号)
    20. # preson = {'name':'周阿狗' ,'age':18}
    21. # print(preson) #{'name': '周阿狗', 'age': 18}
    22. # del preson['age']
    23. # print(preson) #{'name': '周阿狗'}
    24. #
    25. # preson.clear() #删除全部但是保留括号
    26. # print(preson) #{}
    27. # # 字典遍历数据
    28. # preson = {'name':'周阿狗' ,'age':18}
    29. # print(preson) #{'name': '周阿狗', 'age': 18}
    30. # # 遍历preson 的所有key
    31. # for key in preson.keys():
    32. # print(key) # name age
    33. # # 遍历preson 的所有value
    34. # for value in preson.values():
    35. # print(value) # 周阿狗 18
    36. # # 遍历preson 的所有key value
    37. # for key,value in preson.items():
    38. # print(key,value) # name 周阿狗 age 18
    39. # # 遍历preson 的所有项值
    40. # for item in preson.items():
    41. # print(item) #('name', '周阿狗') ('age', 18)

     定义函数

    1. # # 定义函数
    2. # # 练习1
    3. # def f1():
    4. # print('nihao')
    5. # print('woshixiaozhou')
    6. # # 调用函数
    7. # f1()
    8. # # 练习2
    9. # def sun():
    10. # a = 1
    11. # b = 2
    12. # c = a+b
    13. # print(c)
    14. # sun()
    15. # # 练习3
    16. # def sun(a,b): #(形参)
    17. # c = a+b
    18. # print(c)
    19. # # 实参
    20. # sun(100,20)

    函数返回值

    1. # 函数返回值
    2. # # 练习1
    3. # def sun():
    4. # return '冰淇淋'
    5. #
    6. # # 把sun的返回值 赋值给food
    7. # food = sun()
    8. # # 打印的两种形式
    9. # print(food)
    10. # print(sun())
    11. # # 练习2
    12. # def sun(a,b): #(形参)
    13. # c = a+b
    14. # return c
    15. # # 把sun的返回值 赋值给food 要么赋值 输出新值
    16. # food = sun(10,50)
    17. # # 打印的两种形式
    18. # print(food)
    19. # # 或者输出带值
    20. # print(sun(10,50))

    作用域 

    1. # 作用域
    2. # 全局作用域
    3. # a = 100
    4. # def sun():
    5. # print(a)
    6. #
    7. # sun()
    8. #局部作用域
    9. # def sun():
    10. # a = 120
    11. # print(a)
    12. # sun()

    序列化

    异常报错

    1. # 异常提示写法
    2. # try:
    3. # 可能出现的异常
    4. # except 异常类型
    5. # 友好提示
    6. # try:
    7. # fp = open('text.txt','r') #打开这个文件
    8. # fp.read() #读取
    9. # except FileNotFoundError:
    10. # print('没有这个')


    urllib使用

    1. # 引入 urllib
    2. import urllib.request
    3. # 定义路径
    4. url = 'https://baike.baidu.com/'
    5. # 模拟器像服务器端发送请求
    6. response = urllib.request.urlopen(url)
    7. #(3)获取响应中的页面的源码content 内容的意思
    8. # #read方法返回的是字书形式的二进制数据
    9. # 故我们要孵=进制的数据转换为字符串
    10. #二进制--》字符串 解码 decode('编码的格式')
    11. # 获取相应源码
    12. content = response.read().decode('utf-8')
    13. # 打印数据
    14. print(content)

    一个类型六个方法 

    1. # 一个类型和六个方法
    2. # import urllib.request
    3. # # 定义路径
    4. # url = 'https://baike.baidu.com/'
    5. #
    6. # response = urllib.request.urlopen(url)
    7. # 一个类型和六个方法
    8. # response 是 HTTPResponse
    9. # print(type(response)) #<class 'http.client.HTTPResponse'>
    10. # 按照一个字节一个字节的读 读取全部字节
    11. # content = response.read()
    12. # print(content)
    13. # 按照一个字节一个字节的读 read()可以写你要读取多少字节
    14. # content = response.read(4)
    15. # print(content) #b'
    16. # # 按照一个字节一个字节的读 readline()只能读取一行
    17. # content = response.readline()
    18. # print(content) #b'\n'
    19. # # 按照一个字节一个字节的读 readlines()读取全部
    20. # content = response.readlines()
    21. # print(content) #b'\n'
    22. # # 返回状态码 200就是成功返回
    23. # print(response.getcode()) #200
    24. # # 返回路径
    25. # print(response.geturl()) #https://baike.baidu.com/
    26. # # 获取状态信息
    27. # print(response.getheaders()) #[('Content-Type', 'text/html; charset=UTF-8'),

    下载 视频   音频   图片

    1. # 下载
    2. # import urllib.request
    3. # 下载网页
    4. # 定义路径
    5. # url = 'https://baike.baidu.com/'
    6. # urllib.request.urlretrieve(url,'baike.html')
    7. # 下载图片
    8. # https://img0.baidu.com/it/u=3021883569,1259262591&fm=253&fmt=auto&app=120&f=JPEG?w=1140&h=641
    9. # url_img = 'https://lmg.jj20.com/up/allimg/4k/s/02/2109250006343S5-0-lp.jpg'
    10. # urllib.request.urlretrieve(url_img,filename='lisa.jpg')
    11. # 下载视频
    12. # https://vd2.bdstatic.com/mda-picyuf5c6sekhy5c/720p/h264/1694646650126259454/mda-picyuf5c6sekhy5c.mp4?v_from_s=hkapp-haokan-hbf&auth_key=1694690882-0-0-275f5e093e7c5d6af95b829765e00417&bcevod_channel=searchbox_feed&pd=1&cr=2&cd=0&pt=3&logid=1682821669&vid=1074113355220740733&klogid=1682821669&abtest=112751_3
    13. # url_v = 'https://vd2.bdstatic.com/mda-picyuf5c6sekhy5c/720p/h264/1694646650126259454/mda-picyuf5c6sekhy5c.mp4?v_from_s=hkapp-haokan-hbf&auth_key=1694690882-0-0-275f5e093e7c5d6af95b829765e00417&bcevod_channel=searchbox_feed&pd=1&cr=2&cd=0&pt=3&logid=1682821669&vid=1074113355220740733&klogid=1682821669&abtest=112751_3'
    14. # urllib.request.urlretrieve(url_v,'video.mp4')
    图片 

    视频
    网页 

    定制请求对象  是为了防止反爬

    1. # 定制请求对象
    2. import urllib.request
    3. # 定义路径
    4. url = 'https://baike.baidu.com/'
    5. # ua 请求头
    6. headers ={
    7. "User-Agent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/98.0.4758.82 Safari/537.36 Edg/116.0.0.0"}
    8. # 并因为urlopen.方法中不能存储字典两以headers不能传递进去#请求对象的定刹
    9. # #注意因为参数顺序的问题不能疸接写url 和headers中间还有data所以我们需要关键字传参
    10. # 防止反爬 就要携带请求头
    11. request = urllib.request.Request(url = url ,headers = headers)
    12. # 模拟服务器发送请求
    13. response = urllib.request.urlopen(request)
    14. # 读取html页面数据 获取相应源码
    15. content = response.read().decode("utf8")
    16. print(content)

    请求quote

    1. import urllib.request
    2. import urllib.parse
    3. # 定义路径
    4. url = 'https://baike.baidu.com/'
    5. #请求头
    6. headers ={
    7. "User-Agent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/98.0.4758.82 Safari/537.36 Edg/116.0.0.0"
    8. }
    9. #要搜索的对象
    10. name = urllib.parse.quote('百度')
    11. #拼接路径
    12. url = url + name
    13. request = urllib.request.Request(url=url,headers=headers)
    14. # 模拟服务器发送请求
    15. response = urllib.request.urlopen(request)
    16. # 读取html页面数据 获取相应源码
    17. content = response.read().decode("utf8")
    18. print(content)

  • 相关阅读:
    电影太大怎么压缩变小?
    鉴源论坛 · 观模丨嵌入式实时操作系统的形式化验证
    SpringBoot - 如何实现接口幂等性?
    LeetCode - 102. 二叉树的层序遍历;110. 平衡二叉树;098. 验证二叉搜索树
    Windows之应用安装程序 —— winget
    计算机毕业设计springboot+vue基本微信小程序的驾校宝典系统-驾照考试系统
    中介子方程二十二
    Python 潮流周刊#17:Excel 终于支持 Python 了、Meta 重磅开源新项目、Mojo 新得 1 亿美元融资
    Acwing 842. 排列数字
    java基础巩固15
  • 原文地址:https://blog.csdn.net/weixin_68266812/article/details/132873968