python学习之路-2 初识python数据类型
Posted 奋斗中的码农
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了python学习之路-2 初识python数据类型相关的知识,希望对你有一定的参考价值。
数字
- int(整型)
在32位机器上,整数的位数为32位,取值范围为-2**31~2**31-1,即-2147483648~2147483647
在64位系统上,整数的位数为64位,取值范围为-2**63~2**63-1,即-9223372036854775808~9223372036854775807
- long(长整型) – python3 中已经将该类型取消
跟C语言不同,Python的长整数没有指定位宽,即:Python没有限制长整数数值的大小,但实际上由于机器内存有限,我们使用的长整数数值不可能无限大。
注意,自从Python2.2起,如果整数发生溢出,Python会自动将整数数据转换为长整数,所以如今在长整数数据后面不加字母L也不会导致严重后果了。
- float(浮点型)
浮点数用来处理实数,即带有小数的数字。类似于C语言中的double类型,占8个字节(64位),其中52位表示底,11位表示指数,剩下的一位表示符号。
- complex(复数)
复数由实数部分和虚数部分组成,一般形式为x+yj,其中的x是复数的实数部分,y是复数的虚数部分,这里的x和y都是实数。
注:Python中存在小数字池:-5 ~ 257
布尔值
- 真或假
1 或 0
True 或 False
字符串
"hello world"
- 万恶的字符串拼接
python中的字符串在C语言中体现为是一个字符数组,每次创建字符串时候需要在内存中开辟一块连续的空,并且一旦需要修改字符串的话,就需要再次开辟空间,万恶的+号每出现一次就会在内从中重新开辟一块空间。
- 字符串格式化
name = "zhangcong"
print "i am %s " % name
# 输出
i am zhangcong
- 字符串常用功能:
strip() # 去掉字符串首尾空格、换行符、tab
value = " my name is zhangcong "
print(value.strip()) # 会将首尾的空格去掉
# 输出
my name is zhangcong
split() # 通过指定分隔符对字符串进行切片,得到一个列表
names = "zhangsan, lisi, wangwu"
name2 = names.split(",")
print(name2)
# 输出
[‘zhangsan‘, ‘ lisi‘, ‘ wangwu‘]
center() # 返回一个原字符串居中,并使用空格填充至长度 width 的新字符串。默认填充字符为空格。
例1:
value = "my name is zhangcong"
print(value.center(50))
# 输出
my name is zhangcong
例2:
# 使用*填充空格
value = "my name is zhangcong"
print(value.center(50, ‘*‘))
# 输出
***************my name is zhangcong***************
find() # 字符串查找
例1:
# 在字符串value中查找字符串"zhangcong"是否存在,如果存在返回其下标值
value = "my name is zhangcong"
print(value.find("zhang"))
# 输出
11
-
例2:
# 指定开始的位置查找
value = "my name is zhangcong, my name is zhangcong"
print(value.find("zhang", 12))
# 输出
33
capitalize() # 首字母大写,没什么卵用
value = "my name is zhangcong, my name is zhangcong"
print(value.capitalize())
# 输出
My name is zhangcong, my name is zhangcong
upper() # 将字符串里面的所有字母都改为大写
value = "43 fd"
print(value.upper())
# 输出
43 FD
format() 格式化字符串
value = "my name is {}"
print(value.format("zhangcong"))
# 输出
my name is zhangcong
isdigit() # 判断字符串是否是数字类型 返回True 或 False
例1:
value = "my name is {}"
print(value.isdigit())
# 输出
False
-
例2:
num_str = "1000"
print(num_str.isdigit())
# 输出
True
isalnum() # 判断字符是否只含有字母和数字组成 返回True 或 False
例1:
value = "43fd"
print(value.isalnum())
# 输出
True
-
例2:
# value中包含一个空格
value = "43 fd"
print(value.isalnum())
# 输出
False
endswith() # 匹配字符串的结束位置,返回True 或 False
value = "43 fd"
print(value.endswith("fd"))
# 输出
True
-
print(value.endswith("c"))
# 输出
False
startswith() # 匹配字符串的开始位置,返回True 或 False
value = "43 fd"
print(value.startswith("4"))
# 输出
True
-
print(value.startswith("fda"))
# 输出
False
列表
# 创建列表
name_list = ["zhangsan", "lisi", "wangwu"]
或
name_list = list(["zhangsan", "lisi", "wangwu"])
# 通过列表的下标来取对应的值
print(name_list[1])
# 输出
lisi
- 列表常用功能
修改列表中的值
# 将name_list中的 "lisi" 修改为 "liwu"
name_list = ["zhangsan", "lisi", "wangwu"]
name_list[1] = "liwu" # 指定下标修改列表的值
print(name_list)
# 输出
[‘zhangsan‘, ‘liwu‘, ‘wangwu‘]
切片
# 输出name_list中的第一个值和第二个值
name_list = ["zhangsan", "lisi", "wangwu", 1, 2, 3, 4, 5]
print(name_list[1:3]) # 顾头不顾尾
# 输出
[‘lisi‘, ‘wangwu‘]
步长
# 首先创建一个从0到100的列表,不包含100
num_list = list(range(100))
print(num_list[::2])
# 输出
[0, 2, 4, 6, 8, 10, 12, 14, 16, 18, 20, 22, 24, 26, 28, 30, 32, 34, 36, 38, 40, 42, 44, 46, 48, 50, 52, 54, 56, 58, 60, 62, 64, 66, 68, 70, 72, 74, 76, 78, 80, 82, 84, 86, 88, 90, 92, 94, 96, 98]
# 注:通过步长可以取奇偶数
insert() # 指定坐标插入值
# 在列表name_list的值"lisi"前面插入一个值"xiaogou"
name_list = ["zhangsan", "lisi", "wangwu"]
name_list.insert(1, "xiaogou")
print(name_list)
# 输出
[‘zhangsan‘, ‘xiaogou‘, ‘lisi‘, ‘wangwu‘]
append() # 在列表的末尾追加一个值
name_list = ["zhangsan", "lisi", "wangwu"]
name_list.append("xiaogou")
print(name_list)
# 输出
[‘zhangsan‘, ‘lisi‘, ‘wangwu‘, ‘xiaogou‘]
remove() # 删除列表中的指定值
name_list = ["zhangsan", "lisi", "wangwu"]
name_list.remove("lisi")
print(name_list)
# 输出
[‘zhangsan‘, ‘wangwu‘]
# 如果删除的值不在列表中,则会报错
name_list = ["zhangsan", "lisi", "wangwu"]
name_list.remove("lisfdi")
print(name_list)
# 输出报错信息
ValueError: list.remove(x): x not in list
count() # 查找在列表中出现的次数
name_list = ["zhangsan", "lisi", "wangwu", "lisi", 1, 2, 3, 4, 5]
print(name_list.count("lisi")) # 查找"lisi"在列表中出现的次数
# 输出
2
index() # 查找在列表中的下标
name_list = ["zhangsan", "lisi", "wangwu", "lisi", 1, 2, 3, 4, 5]
print(name_list.index("lisi"))
# 输出
1
-
# 如果查找的值在列表中不存在,则会报错
name_list = ["zhangsan", "lisi", "wangwu", "lisi", 1, 2, 3, 4, 5]
print(name_list.index("lisi2"))
# 输出报错信息
ValueError: ‘lisi2‘ is not in list
extend() # 在原先列表的基础之上扩展一个新的列表
name_list = ["zhangsan", "lisi", "wangwu", "lisi"]
name_list2 = [1, 2, 3, 4, 5]
name_list.extend(name_list2)
print(name_list)
# 输出
[‘zhangsan‘, ‘lisi‘, ‘wangwu‘, ‘lisi‘, 1, 2, 3, 4, 5]
reverse() # 将列表的值进行反转
name_list = [‘zhangsan‘, ‘lisi‘, ‘wangwu‘, ‘lisi‘, 1, 2, 3, 4, 5]
name_list.reverse()
print(name_list)
# 输出
[5, 4, 3, 2, 1, ‘lisi‘, ‘wangwu‘, ‘lisi‘, ‘zhangsan‘]
sort() # 排序
# 在python3中,列表中的值同时存在字符串和数字时排序是会报错的,在python2中是没有问题的,python2中是按照ascll编码顺序进行排序的
name_list = [‘zhangsan‘, ‘lisi‘, ‘wangwu‘, ‘lisi‘, 1, 2, 3, 4, 5]
name_list.sort()
# 输错报错信息
TypeError: unorderable types: int() < str()
-
# 对字母进行排序
name_list = [‘zhangsan‘, ‘lisi‘, ‘wangwu‘, ‘lisi‘]
name_list.sort()
print(name_list)
# 输出
[‘lisi‘, ‘lisi‘, ‘wangwu‘, ‘zhangsan‘]
-
# 对数字进行排序
num_list = [3, 4, 1, 100, 3, 5, 6]
num_list.sort()
print(num_list)
# 输出
[1, 3, 3, 4, 5, 6, 100]
pop() # 默认删除列表最后的一个值,并返回删掉的那个值
name_list = [‘zhangsan‘, ‘lisi‘, ‘wangwu‘, ‘lisi‘, ‘44‘]
pop_name = name_list.pop()
print(name_list)
print(pop_name)
# 输出
[‘zhangsan‘, ‘lisi‘, ‘wangwu‘, ‘lisi‘]
44
-
# 指定下标删除列表元素
name_list = [‘zhangsan‘, ‘lisi‘, ‘wangwu‘, ‘lisi‘, ‘44‘]
pop_name = name_list.pop(2)
print(name_list)
print(pop_name)
# 输出
[‘zhangsan‘, ‘lisi‘, ‘lisi‘, ‘44‘]
wangwu
copy() # 浅拷贝 可以通过id()查看内存地址看区别
name_list = [‘zhangsan‘, ‘lisi‘, ‘wangwu‘, ‘lisi‘, ‘44‘]
name_list2 = name_list.copy()
print("name_list: %s" % name_list)
print("name_list2: %s" % name_list2)
# 将name_list中的‘zhangsan‘改为‘liusan‘
name_list[0] = ‘liusan‘
print("修改完之后")
print("name_list: %s" % name_list以上是关于python学习之路-2 初识python数据类型的主要内容,如果未能解决你的问题,请参考以下文章
Python学习之路基础篇--09Python基础,初识函数