高级变量类型

知识点回顾

Python 中数据类型可以分为 数字型非数字型

数字型

  • 整型 (int)

  • 浮点型(float

  • 布尔型(bool

    • True 非 0 数 —— 非零即真

    • False 0

  • 复数型 (complex)

    • 主要用于科学计算,例如:平面场问题、波动问题、电感电容等问题

非数字型

  • 字符串

  • 列表

  • 元组

  • 字典

Python 中,所有 非数字型变量 都支持以下特点:

  1. 都是一个 序列 sequence,也可以理解为 容器

  2. 取值 []

  3. 遍历 for in

  4. 计算长度最大/最小值比较删除

  5. 链接 +重复 *

  6. 切片


列表(其他语言中的数组)

列表的定义

List(列表) 是 Python 中使用 最频繁 的数据类型,在其他语言中通常叫做 数组

专门用于存储 一串 信息

列表用 [] 定义,数据 之间使用 , 分隔

列表的 索引0 开始

name_list = ["zhangsan", "lisi", "wangwu"]

del 关键字

使用 del 关键字(delete) 同样可以删除列表中元素

del 关键字本质上是用来 将一个变量从内存中删除的

如果使用 del 关键字将变量从内存中删除,后续的代码就不能再使用这个变量了

del name_list[1]

在日常开发中,要从列表删除数据,建议 使用列表提供的方法

关键字、函数和方法

关键字 是 Python 内置的、具有特殊意义的标识符

In [1]: import keyword
In [2]: print(keyword.kwlist)
In [3]: print(len(keyword.kwlist))

关键字后面不需要使用括号

函数 封装了独立功能,可以直接调用

函数名(参数)

函数需要死记硬背

方法 和函数类似,同样是封装了独立的功能

方法 需要通过 对象 来调用,表示针对这个 对象 要做的操作

对象.方法名(参数)

在变量后面输入 .,然后选择针对这个变量要执行的操作,记忆起来比函数要简单很多

循环遍历

遍历 就是 从头到尾 依次列表 中获取数据

  • 循环体内部 针对 每一个元素,执行相同的操作

Python 中为了提高列表的遍历效率,专门提供的 迭代 iteration 遍历

使用 for 就能够实现迭代遍历

# for 循环内部使用的变量 in 列表
for name in name_list:循环内部针对列表元素进行操作print(name)

元组(可以存储不同类型的元素)

元组的定义

1、Tuple(元组)与列表类似,不同之处在于元组的 元素不能修改

  • 元组 表示多个元素组成的序列

  • 元组Python 开发中,有特定的应用场景

2、用于存储 一串 信息数据 之间使用 , 分隔

3、元组用 () 定义(列表使用[]进行定义

4、元组的 索引0 开始

info_tuple = ("zhangsan", 18, 1.75)

5、创建空元组

info_tuple = ()

6、元组中 只包含一个元素 时,需要 在元素后面添加逗号

info_tuple = (50, )

循环遍历

取值 就是从 元组 中获取存储在指定位置的数据

遍历 就是 从头到尾 依次元组 中获取数据

​
# for 循环内部使用的变量 in 元组
for item in info:
​循环内部针对元组元素进行操作print(item)
  • Python 中,可以使用 for 循环遍历所有非数字型类型的变量:列表元组字典 以及 字符串

  • 提示:在实际开发中,除非 能够确认元组中的数据类型,否则针对元组的循环遍历需求并不是很多

应用场景

1、尽管可以使用 for in 遍历 元组     但是在开发中,更多的应用场景是:

  1. 函数的 参数 和 返回值,一个函数可以接收 任意多个参数,或者 一次返回多个数

  2. 格式字符串,格式化字符串后面的 () 本质上就是一个元组

  3. 让列表不可以被修改,以保护数据安全

info = ("zhangsan", 18)
​
print("%s 的年龄是 %d" % info)
​2、元组和列表之间的转换

使用 list 函数可以把元组转换成列表

list(元组) 

使用 tuple 函数可以把列表转换成元组

tuple(列表)

字典

字典的定义

1、dictionary(字典) 是 除列表以外 Python 之中 最灵活 的数据类型

  • 字典同样可以用来 存储多个数据

    • 通常用于存储 描述一个 物体 的相关信息

2、和列表的区别

  • 列表有序 的对象集合

  • 字典无序 的对象集合

3、字典用 {} 定义

  • 字典使用 键值对 存储数据,键值对之间使用 , 分隔

    • key 是索引

    • value 是数据

    • 之间使用 : 分隔

    • 键必须是唯一的

    • 可以取任何数据类型,但 只能使用 字符串数字元组

xiaoming = {"name": "小明","age": 18,"gender": True,"height": 1.75}

字典常用操作

ipython3 中定义一个 字典,例如:xiaoming = {}

输入 xiaoming. 按下 TAB 键,ipython 会提示 字典 能够使用的函数如下:

In [1]: xiaoming.
xiaoming.clear       xiaoming.items       xiaoming.setdefault
xiaoming.copy        xiaoming.keys        xiaoming.update
xiaoming.fromkeys    xiaoming.pop         xiaoming.values
xiaoming.get         xiaoming.popitem    

循环遍历

遍历 就是 依次字典 中获取所有键值对

# for 循环内部使用的 `key 的变量` in 字典
for k in xiaoming:
​print("%s: %s" % (k, xiaoming[k]))

提示:在实际开发中,由于字典中每一个键值对保存数据的类型是不同的,所以针对字典的循环遍历需求并不是很多

应用场景

尽管可以使用 for in 遍历 字典   ,但是在开发中,更多的应用场景是:

  • 使用 多个键值对,存储 描述一个 物体 的相关信息 —— 描述更复杂的数据信息

  • 多个字典 放在 一个列表 中,再进行遍历,在循环体内部针对每一个字典进行 相同的处理

card_list = [{"name": "张三","qq": "12345","phone": "110"},{"name": "李四","qq": "54321","phone": "10086"}]

字符串

字符串的定义

字符串 就是 一串字符,是编程语言中表示文本的数据类型。在 Python 中可以使用 一对双引号 " 或者 一对单引号 ' 定义一个字符串。虽然可以使用 \" 或者 \' 做字符串的转义,但是在实际开发中:

  • 如果字符串内部需要使用 ",可以使用 ' 定义字符串

  • 如果字符串内部需要使用 ',可以使用 " 定义字符串

可以使用 索引 获取一个字符串中 指定位置的字符,索引计数从 0 开始

也可以使用 for 循环遍历 字符串中每一个字符

大多数编程语言都是用 " 来定义字符串

string = "Hello Python"
​
for c in string:print(c)

字符串的常用操作

ipython3 中定义一个 字符串,例如:hello_str = ""

输入 hello_str. 按下 TAB 键,ipython 会提示 字符串 能够使用的 方法 如下:

In [1]: hello_str.
hello_str.capitalize    hello_str.isidentifier  hello_str.rindex
hello_str.casefold      hello_str.islower       hello_str.rjust
hello_str.center        hello_str.isnumeric     hello_str.rpartition
hello_str.count         hello_str.isprintable   hello_str.rsplit
hello_str.encode        hello_str.isspace       hello_str.rstrip
hello_str.endswith      hello_str.istitle       hello_str.split
hello_str.expandtabs    hello_str.isupper       hello_str.splitlines
hello_str.find          hello_str.join          hello_str.startswith
hello_str.format        hello_str.ljust         hello_str.strip
hello_str.format_map    hello_str.lower         hello_str.swapcase
hello_str.index         hello_str.lstrip        hello_str.title
hello_str.isalnum       hello_str.maketrans     hello_str.translate
hello_str.isalpha       hello_str.partition     hello_str.upper
hello_str.isdecimal     hello_str.replace       hello_str.zfill
hello_str.isdigit       hello_str.rfind

1) 判断类型 - 9

方法 说明
string.isspace() 如果 string 中只包含空格,则返回 True
string.isalnum() 如果 string 至少有一个字符并且所有字符都是字母或数字则返回 True
string.isalpha() 如果 string 至少有一个字符并且所有字符都是字母则返回 True
string.isdecimal() 如果 string 只包含数字则返回 True,全角数字
string.isdigit() 如果 string 只包含数字则返回 True,全角数字\u00b2
string.isnumeric() 如果 string 只包含数字则返回 True,全角数字汉字数字
string.istitle() 如果 string 是标题化的(每个单词的首字母大写)则返回 True
string.islower() 如果 string 中包含至少一个区分大小写的字符,并且所有这些(区分大小写的)字符都是小写,则返回 True
string.isupper() 如果 string 中包含至少一个区分大小写的字符,并且所有这些(区分大小写的)字符都是大写,则返回 True

2) 查找和替换 - 7

方法 说明
string.startswith(str) 检查字符串是否是以 str 开头,是则返回 True
string.endswith(str) 检查字符串是否是以 str 结束,是则返回 True
string.find(str, start=0, end=len(string)) 检测 str 是否包含在 string 中,如果 start 和 end 指定范围,则检查是否包含在指定范围内,如果是返回开始的索引值,否则返回 -1
string.rfind(str, start=0, end=len(string)) 类似于 find(),不过是从右边开始查找
string.index(str, start=0, end=len(string)) 跟 find() 方法类似,不过如果 str 不在 string 会报错
string.rindex(str, start=0, end=len(string)) 类似于 index(),不过是从右边开始
string.replace(old_str, new_str, num=string.count(old)) 把 string 中的 old_str 替换成 new_str,如果 num 指定,则替换不超过 num 次

3) 大小写转换 - 5

方法 说明
string.capitalize() 把字符串的第一个字符大写
string.title() 把字符串的每个单词首字母大写
string.lower() 转换 string 中所有大写字符为小写
string.upper() 转换 string 中的小写字母为大写
string.swapcase() 翻转 string 中的大小写

4) 文本对齐 - 3

方法 说明
string.ljust(width) 返回一个原字符串左对齐,并使用空格填充至长度 width 的新字符串
string.rjust(width) 返回一个原字符串右对齐,并使用空格填充至长度 width 的新字符串
string.center(width) 返回一个原字符串居中,并使用空格填充至长度 width 的新字符串

5) 去除空白字符 - 3

方法 说明
string.lstrip() 截掉 string 左边(开始)的空白字符
string.rstrip() 截掉 string 右边(末尾)的空白字符
string.strip() 截掉 string 左右两边的空白字符

6) 拆分和连接 - 5

方法 说明
string.partition(str) 把字符串 string 分成一个 3 元素的元组 (str前面, str, str后面)
string.rpartition(str) 类似于 partition() 方法,不过是从右边开始查找
string.split(str="", num) 以 str 为分隔符拆分 string,如果 num 有指定值,则仅分隔 num + 1 个子字符串,str 默认包含 '\r', '\t', '\n' 和空格
string.splitlines() 按照行('\r', '\n', '\r\n')分隔,返回一个包含各行作为元素的列表
string.join(seq) 以 string 作为分隔符,将 seq 中所有的元素(的字符串表示)合并为一个新的字符串

字符串的切片

切片 方法适用于 字符串列表元组

  • 切片 使用 索引值 来限定范围,从一个大的 字符串切出 小的 字符串

  • 列表元组 都是 有序 的集合,都能够 通过索引值 获取到对应的数据

  • 字典 是一个 无序 的集合,是使用 键值对 保存数据

字符串[开始索引:结束索引:步长]

注意

1、指定的区间属于 左闭右开[开始索引, 结束索引) 。从 起始 位开始,到 结束位的前一位 结束(不包含结束位本身)

2、从头开始,开始索引 数字可以省略,冒号不能省略

3、到末尾结束,结束索引 数字可以省略,冒号不能省略

4、步长默认为 1,如果连续切片,数字和冒号都可以省略

索引的顺序和倒序

在 Python 中不仅支持 顺序索引,同时还支持 倒序索引。所谓倒序索引就是 从右向左 计算索引

  • 最右边的索引值是 -1,依次递减

实践

num_str = "0123456789"
​
# 1. 截取从 2 ~ 5 位置 的字符串
print(num_str[2:6])
​
# 2. 截取从 2 ~ `末尾` 的字符串
print(num_str[2:])
​
# 3. 截取从 `开始` ~ 5 位置 的字符串
print(num_str[:6])
​
# 4. 截取完整的字符串
print(num_str[:])
​
# 5. 从开始位置,每隔一个字符截取字符串
print(num_str[::2])
​
# 6. 从索引 1 开始,每隔一个取一个
print(num_str[1::2])
​
# 倒序切片
# -1 表示倒数第一个字符
print(num_str[-1])
​
# 7. 截取从 2 ~ `末尾 - 1` 的字符串
print(num_str[2:-1])
​
# 8. 截取字符串末尾两个字符
print(num_str[-2:])
​
# 9. 字符串的逆序(面试题)
print(num_str[::-1])

公共方法

Python 内置函数

函数 描述 备注
len(item) 计算容器中元素个数  
del(item) 删除变量 del 有两种方式
max(item) 返回容器中元素最大值 如果是字典,只针对 key 比较
min(item) 返回容器中元素最小值 如果是字典,只针对 key 比较
cmp(item1, item2) 比较两个值,-1 小于/0 相等/1 大于 Python 3.x 取消了 cmp 函数

注意——字符串 比较符合以下规则: "0" < "A" < "a"

切片

描述 Python 表达式 结果 支持的数据类型
切片 "0123456789"[::-2] "97531" 字符串、列表、元组
  1. 切片 使用 索引值 来限定范围,从一个大的 字符串切出 小的 字符串

  2. 列表元组 都是 有序 的集合,都能够 通过索引值 获取到对应的数据

  3. 字典 是一个 无序 的集合,是使用 键值对 保存数据

运算符

运算符 Python 表达式 结果 描述 支持的数据类型
+ [1, 2] + [3, 4] [1, 2, 3, 4] 合并 字符串、列表、元组
* ["Hi!"] * 4 ['Hi!', 'Hi!', 'Hi!', 'Hi!'] 重复 字符串、列表、元组
in 3 in (1, 2, 3) True 元素是否存在 字符串、列表、元组、字典
not in 4 not in (1, 2, 3) True 元素是否不存在 字符串、列表、元组、字典
> >= == < <= (1, 2, 3) < (2, 2, 3) True 元素比较 字符串、列表、元组

注意

  • in 在对 字典 操作时,判断的是 字典的键

  • innot in 被称为 成员运算符

成员运算符

成员运算符用于 测试 序列中是否包含指定的 成员

运算符 描述 实例
in 如果在指定的序列中找到值返回 True,否则返回 False 3 in (1, 2, 3) 返回 True
not in 如果在指定的序列中没有找到值返回 True,否则返回 False 3 not in (1, 2, 3) 返回 False

注意:在对 字典 操作时,判断的是 字典的键

完整的 for 循环语法

Python 中完整的 for 循环 的语法如下:

for 变量 in 集合:循环体代码
else:没有通过 break 退出循环,循环结束后,会执行的代码

应用场景

迭代遍历 嵌套的数据类型时,例如 一个列表包含了多个字典

需求:要判断 某一个字典中 是否存在 指定的 值

  • 如果 存在,提示并且退出循环

  • 如果 不存在,在 循环整体结束 后,希望 得到一个统一的提示

students = [{"name": "阿土","age": 20,"gender": True,"height": 1.7,"weight": 75.0},{"name": "小美","age": 19,"gender": False,"height": 1.6,"weight": 45.0},
]find_name = "阿土"for stu_dict in students:print(stu_dict)# 判断当前遍历的字典中姓名是否为find_nameif stu_dict["name"] == find_name:print("找到了")# 如果已经找到,直接退出循环,就不需要再对后续的数据进行比较breakelse:print("没有找到")print("循环结束")

Python基础(四)(列表、元组、字典、字符串、Python内置函数、切片、运算符、成员运算符)相关推荐

  1. 《Python 1》--python的简介、解释器、读取键盘输入函数、变量类型推断、5个标准数据类型、字符串的内置函数、for循环、list列表、tuple元组、字典dictionary

    Python 的起源: Python 的创始人为吉多·范罗苏姆(Guido van Rossum) 1. 1989 年的圣诞节期间,吉多·范罗苏姆为了在阿姆斯特丹打发时间,决心开发一个新的**解释程序 ...

  2. python 高级变量类型(列表/元组/字典/字符串)

    前言 Python 中数据类型可以分为 数字型 和 非数字型 数字型 整型 (int) 浮点型(float) 布尔型(bool) 真 True 非 0 数 -- 非零即真 假 False 0 复数型 ...

  3. Day2 - Python基础2 列表、字典、集合 --转自金角大王

    Day2 - Python基础2 列表.字典.集合 --转自金角大王 Posted on 2018-01-24 13:23 Byd_lei 阅读(41) 评论(0)  编辑 收藏 本节内容 列表.元组 ...

  4. format函数python生成列表_python 全栈开发,Day14(列表推导式,生成器表达式,内置函数)...

    一.列表生成式 生成1-100的列表 li = [] for i in range(1,101): li.append(i) print(li) 执行输出: [1,2,3...] 生成python1期 ...

  5. string是python内置函数吗_Python 字符串与内置函数(方法)

    一.字符串 1.字符串定义 a.定义时用成对双引号或成对单引号 b.也可以用成对的三个双引号或成对的三个单引号定义字符串(定义的字符串用包含单引号或双引号时可以用这个方法) c.字符串中间有单引号时, ...

  6. python中求包含5的数_Python 内置函数 ( ) 可以返回列表、元组、字典、集合、字符串以及 range 对象中元素个数。_学小易找答案...

    [简答题]实例1:求两数相除的结果. 先后输入2个数据,计算第一个数除以第二个数的结果. 要求能够处理输入数据为非数字.除数为零.文件末尾EndOfFile 和用户使用Ctrl + C 命令终止程序等 ...

  7. Day2 - Python基础2 列表、字典、集合

    Python之路,Day2 - Python基础2 本节内容 列表.元组操作 字符串操作 字典操作 集合操作 文件操作 字符编码与转码 1. 列表.元组操作 列表是我们最以后最常用的数据类型之一,通过 ...

  8. *python高级数据-列表-元组-字典

    列表list 列表用来存放多条数据:字符串.int.list.dict等都可以 储存一系列名字,存储一些新闻条目,可以使用列表的格式. # 例如 Name = '张三' Name2 = 'lisi' ...

  9. mysql cbrt函数_基础方法或属性: 列表,元组,字典,字符串,集合及内置函数等(注:只有英文名)...

    列表 list append clear copy count extend index insert pop remove reverse sort 元组 tuple count index 字典 ...

  10. 【Python中的】列表生成式和字典生成式以及内置函数

    前言: 在Python中可以使用列表生成式进行代码的简化,并且提高代码的运行效率, Python中的内置函数可以使得在工作需求中,进行简单的代码运算并且不再进行 相应的函数定义,可以提高工作效率,本篇 ...

最新文章

  1. 对比tensorflow查看打印输出张量Tensor的两种方法(急切执行tf.enable_eager_execution()和tf.Session.run())
  2. springcloud api-gateway详解
  3. DCMTK:OFDate, OFTime and OFDateTime类的测试程序
  4. Http协议(6)—安全HTTP
  5. Redmine数据库备份及搬家
  6. mysql error trace_防止DedeCMS错误警告日志data/mysql_error_trace.inc暴露后台管
  7. 随想录(mysql之基础篇)
  8. 金山手机卫士论坛_三星多款手机黑屏系统崩溃 客服:闰4月BUG,无法保证数据不丢失...
  9. dubbo 服务压测_不可忽视的Dubbo线程池
  10. 十几位资深架构师,整理了最新架构师学习体系,分享给大家......
  11. 考完试 记录一下复习资料 人工智能原理知识点整理
  12. 解决看网课鼠标不能移开,视频不能加速
  13. numpy 矩阵运算
  14. 【verilog】按键消抖(FPGA,低电平有效按键,状态机法)
  15. Xcode8/iOS10 升级后遇到的问题小结
  16. 技术文档 | 5G系统连接管理:CM空闲和CM已连接
  17. Jeesite4图片上传
  18. 解决Ubuntu18.04下VMware开启虚拟网络编辑器无反应
  19. c语言单链表的按序号查找,以下为单链表按序号查找的运算,分析算法,请在______处填上正确的语句。 pointer find_lklist(1kl...
  20. 6.2 漫反射-半兰伯特

热门文章

  1. 我的MBTI性格测试
  2. 教育培训app开发迅速成长的原因是?未来趋势如何?
  3. 教育系统+直播APP开发设计
  4. proc wifi 开启_一步一步教你解锁newifi3(新路由3)并编译刷入最新官方OpenWrt
  5. 京东全网手机爬虫scrapy_redis及决策树数据分析
  6. 魔术方法2-上下文管理
  7. 入职五年回顾(十三) 2013年8月
  8. 传递函数的幅值计算公式_场地传递函数幅值谱的模拟计算
  9. VulnHub靶机-Jangow: 1.0.1
  10. 【预训练语言模型】RoBERTa: A Robustly Optimized BERT Pretraining Approach