当前位置: 首页 > news >正文

2-python的变量类型

内容提要

主要回顾了python中的变量类型,区分它们和c++中的区别
python中的数字没有long
python中的字符串不能被改变,也就是说不能对其内字符元素进行赋值操作
python中列表的数据类型与c++访问方式有一定的区别列表的下标可以是负数,无论正负,都是从左侧开始,从左到右依次递增。还有截取操作[头:尾:步长),+表示连接,*表示重复。
列表与元组类型的区别
字典类型的使用(类似于map)

python的变量类型

python中常见的数据类型:

  • Numbers(数字)
  • String(字符串)
  • bool (布尔类型)
  • List(列表)
  • Tuple(元组)
  • Dictionary(字典)
  • Set (集合)

python中的变量不需要声明,变量的赋值操作既是变量声明和定义的过程。 这和C++很不一样。

string 字符串类型

字符串类型的访问方式和C++有些许区别

字串列表的取值顺序有两种,从左到右和从右到左,从左到右的索引是从0开始的,从右到左的索引是从-1开始的。

python-string-slice.png

ss = "Hello World!"
print(ss[0])
print(ss[-1])
print(type(ss))
H
!
<class 'str'>

如果要实现从字符串中截取一段子串的话,可以使用[头下标:尾下标]来截取相应的字符串,其中下标是从0开始算起的,可以是正数或者负数,下标可以为空表示取到头或者尾。

s = "Hello World!"
s1 = s[0:5]
print(s1)
s2 = s[6:]
print(s2)
Hello
World!
s = "Hello World!"
s1 = s[-7:-1]
print(s1)
s2 = s[-7:]
print(s2)
 WorldWorld!

所以,头坐标都是相对于左边的,尾下标都是相对于右边的。

而且,这个[头坐标:尾座标] 其实是数学中的前闭后开区间,也就是截取的范围是[头坐标:尾坐标)

s = "Hello World!"
s1 = s[:-1]
print(s1)
s2 = s[:2]
print(s2)
Hello World
He

同理,头坐标也是可以进行省略的,如果省略的话,就表示从头开始截取。再次强调❗️头坐标是相对于左边的。
最左边都是最小值,最右边都是最大值,只不过负数的最大和最小与其绝对值正好相反。

Python 列表截取可以接收第三个参数,参数作用是截取的步长,以下实例在索引 1 到索引 4 的位置并设置为步长为 2(间隔一个位置)来截取字符串:也就是这个样子的[头坐标:尾坐标:步长]

如果步长为负数,则表示为逆向输出。

s = "Hello World!"
s1 = s[0:5:2] # [0,5),步长为2,每间隔一个字符取一个进行输出
print(s1)
s2 = s[::-1] # 字符串反转
print(s2) 
Hlo
!dlroW olleH

🐖:Python 使用反斜杠 \ 转义特殊字符,如果你不想让反斜杠发生转义,可以在字符串前面添加一个 r,表示原始字符串

print("hello\nworld")
print(r"hello\nworld")
hello
world
hello\nworld

🐖:python中的字符串不能被改变,这一点和c中的字符串是不同的

比如:向一个索引位置进行赋值操作,就会报错。

s = "Hello World!"
s[-1] = "d" # 字符串是不可变类型,不能直接修改字符串中的某个字符
---------------------------------------------------------------------------TypeError                                 Traceback (most recent call last)Cell In[4], line 21 s = "Hello World!"
----> 2 s[-1] = "d" # 字符串是不可变类型,不能直接修改字符串中的某个字符TypeError: 'str' object does not support item assignment
s = "Hello World!"
print(s)
s = 'haha'
print(s)
Hello World!
haha

list 列表类型

列表可以完成大多数集合类的数据结构实现,比如队列、栈等。

它支持字符、数字、字符串甚至可以包含列表(即嵌套)。

列表直接用中括号[]表示,内部元素用逗号,隔开。

和字符串一样,列表同样可以被索引和截取,列表被截取后返回一个包含所需元素的新列表。

对了,列表中和字符串类似,也可以使用[头坐标:尾坐标:步长]来截取。同时,+表示连接运算符,*是重复操作。

list1 = [1,2,'hello','world']
print(list1)print(list1[0::2])print(list1 * 2)print(list1 + [3,4,5])# print(list1 + 1) # 报错print(type(list1))
[1, 2, 'hello', 'world']
[1, 'hello']
[1, 2, 'hello', 'world', 1, 2, 'hello', 'world']
[1, 2, 'hello', 'world', 3, 4, 5]
<class 'list'>

列表竟然还可以直接用加号来拼接,这简直了!!!
🐖 需要注意的是,➕只能用来连接同种类型的数据,比如列表只能和列表连接,字符串只能和字符串连接,不能混着来。

# print('111'+1) # 报错

tuple 元组类型

元组类似于列表,但是 元组的元素不能修改 ,元组使用小括号(),列表使用方括号[]

tuple1 = (1,2,'hello','world',(4,5,6))
print(tuple1)
print(tuple1[4][0:2])
print(tuple1[4][0:2][0])
for e in tuple1:print(type(e))
(1, 2, 'hello', 'world', (4, 5, 6))
(4, 5)
4
<class 'int'>
<class 'int'>
<class 'str'>
<class 'str'>
<class 'tuple'>

总之,对于tuple来说,只需要记住,它和list的不同之处在于,tuple是不可变的,而list是可变的。

set 集合类型

集合(set)是由一个或数个形态各异的大小整体组成的,构成集合的事物或对象称作元素或是成员

基本功能是进行成员关系测试删除重复元素。重复的元素被自动去掉

set 可以进行集合的运算。 集合的运算包括:交集、并集、差集等。

可以使用大括号 { } 或者 set() 函数创建集合,

🐖:创建一个空集合必须用 set() 而不是 { },因为 { } 是用来创建一个空字典。

aset = {1,2,3,4,1,1,13,3,4,5,6,7,8,9,0}
print('aset: ',aset)
bset = {1,2,3,100}
print('aset - bset: ',aset - bset)
print('aset & bset: ',aset & bset)
print('aset | bset: ',aset | bset)cset = set()
print(type(cset))
ddic = {}
print(type(ddic))
aset:  {0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 13}
aset - bset:  {0, 4, 5, 6, 7, 8, 9, 13}
aset & bset:  {1, 2, 3}
aset | bset:  {0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 100, 13}
<class 'set'>
<class 'dict'>

dictionary 字典类型

列表是有序的对象集合,而字典是无序的对象集合。

字典当中的元素是通过键来存取的,而不是通过偏移存取。 类似于C++中的map。

字典用{} 来进行标识,字典由索引(key)和它对应的值value组成。

dict = {}
dict['one'] = "This is one"
dict[2] = "This is two"
tinydict = {'name':'john','code':6734,'dept':'sales'}
print(dict['one'])
print(dict[2])
print(tinydict)
print(tinydict.keys())
print(tinydict.values())
print(type(tinydict))
This is one
This is two
{'name': 'john', 'code': 6734, 'dept': 'sales'}
dict_keys(['name', 'code', 'dept'])
dict_values(['john', 6734, 'sales'])
<class 'dict'>

bytes 字节类型

bytes类型是python3中的新类型,它的实例是一个0<= x <256的整数序列。

bytes 类型通常用于处理二进制数据,比如图像文件、音频文件、视频文件等等。在网络编程中,也经常使用 bytes 类型来传输二进制数据。

创建 bytes 对象的方式有多种,最常见的方式是使用 b 前缀,也可以通过调用 bytes() 构造器得到 bytes 对象。bytes()传入两个参数,第一个参数是字符串,第二个参数是编码方式,默认是utf-8。

x = b'hello'
print(type(x))
print(x)
print("bytes类型中的元素是整数值,而不是单个字符。")
print("x[0]: ",x[0]) # 104
<class 'bytes'>
b'hello'
bytes类型中的元素是整数值,而不是单个字符。
x[0]:  104

🐖:bytes 类型中的元素是整数值,因此在进行比较操作时需要使用相应的整数值

x = b"hello"
if x[0] == ord("h"):print("The first element is 'h'")
The first element is 'h'

总结

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-vEkWAPMJ-1685179378731)(https://img.picgo.net/2023/05/27/20230527171656547abf21de4c3753.png)]

http://www.lryc.cn/news/90665.html

相关文章:

  • Python之并发编程一背景知识
  • Redis分区
  • 代码随想录算法训练营第56天 | 583、72
  • c++输入输出文件操作stream
  • 【小呆的力学笔记】非线性有限元的初步认识【三】
  • python计算闰年
  • 聊聊如何使用Js写一个简单的二级联动和三级联动呢?
  • IPv4 和 IPv6 的特点、区别以及在互联网中的应用
  • JavaScript处理移动web交互
  • 4年测试经验,一问三不知,过于离谱...
  • Java 与查找算法(2)二分查找
  • Java程序设计入门教程--原始类与包装类
  • pip安装python库速度慢、失败及超时报错解决办法
  • 向量数据库
  • leetcode 11.盛最多水的容器
  • 都说00后已经躺平了,但是有一说一,该卷的还是卷啊。
  • 牛客网刷题学习SQL(二)
  • 深蓝学院 C++笔记 先导篇章 - 绪论
  • R7-19 天梯赛团队总分
  • 使用 Kotlin 的 Opt-in (选择加入)功能注解API提示当前非稳定API
  • webpack配置排除打包
  • HNU-操作系统OS-ucoreLab系列-感悟
  • MySQL运维篇(三)
  • Lecture 2 Text Preprocessing
  • web练习第二周
  • LC-1439. 有序矩阵中的第 k 个最小数组和(二分答案、多路归并)
  • 一文1000字从0到1实现Jenkins+Allure+Pytest的持续集成
  • 给一个有序数组生成平衡搜索二叉树(java)
  • 【JavaSE】Java基础语法(二十二):包装类
  • javascript基础十八:说说你对JavaScript中事件循环的理解​