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

2023-11-15

切片

# # 切片

# s = 'hello word'

# # 下标索引为0的
# print(s[0]) #h

# # 左闭右开  (左是下标开始的,右是几个索引值)例如从0开始算 4个索引值
# print(s[0:4]) #hell

# # 更改起始值的开始位置
# print(s[1:]) #ello word

# # 下标结束位置
# print(s[:5]) #hello

# #从下标为0的位匿开始到下标为6的位置结束每次增长2个长度
# print(s[0:6:2]) #hlo

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


# 字典查询
# preson = {'name':'周阿狗' ,'age':18}
# # 查询方式
# print(preson['name']) #周阿狗   直接打印name的值
# print(preson.get('age')) #18    可以使用get获取值
# # print(preson["sex"])  #报错 因为没有sex KeyError: 'sex'




# 字典修改  preson['name'] 选的有的数据进行修改   没有的就是添加 有的就是修改
# preson = {'name':'周阿狗' ,'age':18}
# print(preson)  #{'name': '周阿狗', 'age': 18}
# preson['name'] = '张三'
# print(preson)  #{'name': '张三', 'age': 18}




# # 字典添加  preson['sex']没有的进行添加  没有的就是添加 有的就是修改
# preson = {'name':'周阿狗' ,'age':18}
# print(preson)  #{'name': '周阿狗', 'age': 18}
# preson['sex'] = '男'
# print(preson)  #{'name': '周阿狗', 'age': 18, 'sex': '男'}
# preson['name'] = '张三'
# print(preson)  #{'name': '张三', 'age': 18, 'sex': '男'}




# # 字典删除  del不可以删除对象(preson)  clear 删除全部但是保留对象(括号)
# preson = {'name':'周阿狗' ,'age':18}
# print(preson)  #{'name': '周阿狗', 'age': 18}
# del preson['age']
# print(preson)  #{'name': '周阿狗'}
#
# preson.clear() #删除全部但是保留括号
# print(preson)  #{}




# # 字典遍历数据
# preson = {'name':'周阿狗' ,'age':18}
# print(preson)  #{'name': '周阿狗', 'age': 18}


# # 遍历preson 的所有key值
# for key in preson.keys():
#     print(key)  # name  age


# # 遍历preson 的所有value值
# for value in preson.values():
#     print(value)  # 周阿狗  18


# # 遍历preson 的所有key  value值
# for key,value in preson.items():
#     print(key,value)  # name 周阿狗  age 18


# # 遍历preson 的所有项值
# for item in preson.items():
#     print(item)  #('name', '周阿狗') ('age', 18)

 定义函数


# # 定义函数
# # 练习1
# def f1():
#     print('nihao')
#     print('woshixiaozhou')

# # 调用函数
# f1()



# # 练习2
# def sun():
#     a = 1
#     b = 2
#     c = a+b
#     print(c)

# sun()



# # 练习3
# def sun(a,b):  #(形参)
#     c = a+b
#     print(c)

# # 实参
# sun(100,20)

函数返回值


# 函数返回值
# # 练习1
# def sun():
#     return '冰淇淋'
#
# # 把sun的返回值 赋值给food
# food = sun()
# # 打印的两种形式
# print(food)
# print(sun())


# # 练习2
# def sun(a,b):  #(形参)
#     c = a+b
#     return c

# # 把sun的返回值 赋值给food   要么赋值 输出新值
# food = sun(10,50)

# # 打印的两种形式
# print(food)
# # 或者输出带值
# print(sun(10,50))

作用域 


 # 作用域
 # 全局作用域
# a = 100
# def sun():
#  print(a)
#
# sun()

#局部作用域
# def sun():
#  a = 120
#  print(a)
# sun()

序列化

异常报错

# 异常提示写法
# try:
#     可能出现的异常
# except 异常类型
#     友好提示


# try:
#     fp = open('text.txt','r')  #打开这个文件
#     fp.read() #读取
# except FileNotFoundError:
#     print('没有这个')

 


urllib使用

# 引入 urllib
import urllib.request

# 定义路径
url = 'https://baike.baidu.com/'

# 模拟器像服务器端发送请求
response = urllib.request.urlopen(url)


#(3)获取响应中的页面的源码content 内容的意思
# #read方法返回的是字书形式的二进制数据
# 故我们要孵=进制的数据转换为字符串
#二进制--》字符串  解码  decode('编码的格式')
# 获取相应源码
content = response.read().decode('utf-8')


# 打印数据
print(content)

 

一个类型六个方法 


# 一个类型和六个方法
# import urllib.request
# # 定义路径
# url = 'https://baike.baidu.com/'
# 
# response = urllib.request.urlopen(url)

# 一个类型和六个方法
# response 是  HTTPResponse
# print(type(response))   #<class 'http.client.HTTPResponse'>


# 按照一个字节一个字节的读  读取全部字节
# content = response.read()
# print(content)


# 按照一个字节一个字节的读  read()可以写你要读取多少字节
# content = response.read(4)
# print(content)  #b'<!DO'


# # 按照一个字节一个字节的读  readline()只能读取一行
# content = response.readline()
# print(content)  #b'<!DOCTYPE html>\n'


# # 按照一个字节一个字节的读  readlines()读取全部
# content = response.readlines()
# print(content)  #b'<!DOCTYPE html>\n'


# # 返回状态码  200就是成功返回
# print(response.getcode())  #200


# # 返回路径
# print(response.geturl())  #https://baike.baidu.com/



# # 获取状态信息
# print(response.getheaders())  #[('Content-Type', 'text/html; charset=UTF-8'),







下载 视频   音频   图片

# 下载
# import urllib.request

# 下载网页
# 定义路径
# url = 'https://baike.baidu.com/'
# urllib.request.urlretrieve(url,'baike.html')

# 下载图片
# https://img0.baidu.com/it/u=3021883569,1259262591&fm=253&fmt=auto&app=120&f=JPEG?w=1140&h=641
# url_img = 'https://lmg.jj20.com/up/allimg/4k/s/02/2109250006343S5-0-lp.jpg'
# urllib.request.urlretrieve(url_img,filename='lisa.jpg')


# 下载视频
# 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
# 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'
# urllib.request.urlretrieve(url_v,'video.mp4')

图片 

视频

网页 

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

# 定制请求对象
import urllib.request
# 定义路径
url = 'https://baike.baidu.com/'

# ua 请求头
headers ={
      "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"}

# 并因为urlopen.方法中不能存储字典两以headers不能传递进去#请求对象的定刹
# #注意因为参数顺序的问题不能疸接写url 和headers中间还有data所以我们需要关键字传参
# 防止反爬 就要携带请求头 
request = urllib.request.Request(url = url ,headers = headers)

# 模拟服务器发送请求
response = urllib.request.urlopen(request)

# 读取html页面数据 获取相应源码
content = response.read().decode("utf8")
print(content)

请求quote


import urllib.request
import urllib.parse

# 定义路径
url = 'https://baike.baidu.com/'

#请求头
headers ={
      "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"
}

#要搜索的对象
name = urllib.parse.quote('百度')

#拼接路径
url = url + name


request = urllib.request.Request(url=url,headers=headers)

# 模拟服务器发送请求
response = urllib.request.urlopen(request)

# 读取html页面数据 获取相应源码
content = response.read().decode("utf8")
print(content)

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

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

随机推荐

  • FP64、FP32、FP16、FP8简介

    目录 1 单精度浮点数FP32的表示 2 半精度浮点数FP16的表示 3 双精度浮点数FP64的表示 4 FP8 5 写在最后 1 单精度浮点数FP32的表示 浮点数由三部分组成 符号位 指数部分 尾数部分 以单精度浮点数为例 如图所示 符
  • 好多粉使用百度OCPC api提交后如何手动选择有效咨询回传?

    推广每天会有复制 虽然绝大部分是正常的数据 但也有可能有的是同行刷的 有的是没有添加成功的数据 如果不处理 会造成无效数据上传 只能投放的AI可能就要被某些别有用心的人玩坏了 所以我们为解决这个痛点 开发了手动回传功能 并且系统自动帮你标识
  • VS2019现有项目添加Qt界面

    目录 Qt安装教程 Qt下载 Qt安装 VS Qt插件 配置Qt插件 配置包含目录及链接器 添加QT界面 添加UI界面 配置文件属性 编译UI文件 添加 h和 cpp文件 简单运行测试 双击ui文件打开Qt Designer闪退问题 与VS
  • c++实现霍夫曼编码

    c 实现霍夫曼编码 计算信源的熵 平均码长 编码效率 冗余度与压缩比 考虑到指针可能对新手不太友好 这里用的是vector容器 用法类似数组 可以动态扩容 存储树形结构 大致原理就是n号结点的左右子树分别是2n和2n 1号结点 Huffma
  • XMPP客户端库Smack 4.1.4版官方开发文档之五

    本文转载自 博客主页 http blog csdn net chszs 五 名单Roster和在线状态Presence 名单可以让你跟踪其他用户是否在线 而且名单可以让你把用户组织到群组 比如朋友群或工作群 而其它的即时通信IM系统则把名单
  • 7个高频出现的面试题

    收集了2022年所有学生的面试题后 我整理出了7个高频出现的面试题 一起来看看 高频问题1 请自我介绍下 高频问题2 请介绍下最近做过的项目 高频问题3 请介绍下你印象深刻的bug 高频问题4 Fiddler工具怎么使用的 高频问题5 说一
  • 判断是否为数字的两种办法

    今天在写angular的ts中碰到一个问题 就是需要判断用户id是否是number类型还是uuid 在这里我采用了两种办法 1 使用typeof 判断是什么类型 if typeof res userInfo id number alert
  • sar 命令

    NAME sar Collect report or save system activity information SYNOPSIS sar A b B C d h i interval m p q r R S t u ALL v V
  • 2.2 SSD之地址映射

    LBA Logical Block Address 表示用户操作 读写 数据的位置 PBA Physics Block Address 表示数据在硬盘的真实位置 在HDD时代 数据可以覆盖写 LBA和PBA直接对应不会更改 但是SSD时代
  • leetcode-453. 最小操作次数使数组元素相等-js

    题目 代码 关键 每次操作使 n 1 个元素增加 1 相当于使1个元素减小 1 所以算出每个元素减小到最小元素的次数即可 var minMoves function nums const minNum Math min nums retur
  • BootStrap-table 复选框默认选中(checkbox)

    BootStrap table 复选框默认选中 checkbox bootstrap table colums 写法 var columns field checked checkbox true formatter stateFormat
  • 基于深度学习的人脸识别综述

    本文转载自 https xraft github io 2018 03 21 FaceRecognition 作者 Caleb Ge 葛政 如有侵权请告知删除 下文中的 我 均为原文作者 另附有查找的其他参考链接 论文介绍方面链接 1 ht
  • 第三章-Python中的数据类型

    欢迎来到python的世界 博客主页 卿云阁 欢迎关注 点赞 收藏 留言 本文由卿云阁原创 本阶段属于练气阶段 希望各位仙友顺利完成突破 首发时间 2021年3月14日 希望可以和大家一起完成进阶之路 作者水平很有限 如果发现错误 请留言轰
  • ubuntu下编译问题集锦

    1 DSO missing from command line 一般是库链接顺序不对 将依赖于其他库的lib放在前面 库放在后面就行 2 fatal error ceres ceres h No such file or directory
  • CTF中那些脑洞大开的编码和加密

    0x00 前言 正文开始之前先闲扯几句吧 玩CTF的小伙伴也许会遇到类似这样的问题 表哥 你知道这是什么加密吗 其实CTF中脑洞密码题 非现代加密方式 一般都是各种古典密码的变形 一般出题者会对密文进行一些处理 但是会给留一些线索 所以写此
  • vant使用时覆盖默认样式

    在我们使用vant的时候 有时候一些组件的默认样式并不能满足我们项目的需求 这个时候我们可以使用下面的办法 覆盖掉默认样式 亲测有效 vant覆盖默认样式的写法 v deep van cell not last child after le
  • transform的scale属性实现对大屏的适配

    最近公司做的大屏用到了transform的scale属性来对大屏网页 进行缩放 缺点 需要给项目大屏 设定固定的宽高 当使用的屏幕分辨率和项目不一致时 会出现左右或者上下的留白 如果设计稿是1920 1080的尺寸 项目中用px来写宽高的话
  • QT 自学内容 day06 文件的打开,读取,写入,输出内容的时候编码方式的修改,文件的创建日期,和最后的修改时间

    1 打开文件 头文件 include
  • 在图像间进行特征匹配

    特征匹配 目标 我们将要学习在图像间进行特征匹配 使用 OpenCV 中的蛮力 Brute Force 匹配和 FLANN 匹配 Brute Force 匹配的基础 蛮力匹配器是很简单的 首先在第一幅图像中选取一个关键点然后依次与第二幅图像
  • python自(2)切片 字典 遍历删除添加修改查询定义函数函数返回值作用域序列化异常报错urllib使用一个类型六个方法下载 视频音频图片

    切片 切片 s hello word 下标索引为0的 print s 0 h 左闭右开 左是下标开始的 右是几个索引值 例如从0开始算 4个索引值 print s 0 4 hell 更改起始值的开始位置 print s 1 ello wor