python数据类型操作_python的数据类型及操作

简述python的几种简单的数据类型及使用方式

引入内存空间得概念,开辟一个数字类型占32位(32位机器),一个字符占8位bit。

当图中每个bytes都是char类型得时候,那么从内存取出来就是转换成字符(按编码表转换)。

字符串

字符串是不可变数据类型,拥有多种内置方法可以操作。

创建字符串就是给变量分配一个字符串的值即可。通常用引号创建字符串。

tell = 'my name is Jeff'tell1= "my name is Jeff"tell2= '''my name is Jeff,

I'm oldboy .'''

字符串切片

tell = 'my name is Jeff'

print(tell[0])print(tell[:7])print(tell[:7]+'\tfrank')

运行结果

m

my name

my name frank

使用split方法

tell = "my name is jeff"

print(tell.split('a'))

运行结果

['my n', 'me is jeff']

字符串格式化输出

print('my name is %s'%('jeff'))

运行结果

my nameis jeff

print('my name is {name}'.format(name='jeff'))

运行结果

my nameis jeff

字符串的内置方法

1.capitalize(整个字符串首字母大写,其他全部改为小写)

2.upper(整个字符串全部大写)lower(全部小写)

3.center(指定宽度和填充字符)

tell = "my name Is jeff"

print(tell.center(50,'*'))

运行结果*****************my name Is jeff *****************

4.count(区间内某个字符的个数)

tell = "my name Is jeff"

print(tell.count('m',0,5))

运行结果1

5.encode(编码方式)

6.endswith(以某字符,字符串结尾)

tell = "my name Is jeff"

print(tell.endswith("ff"))

运行结果

Ture

7.expandtabs(选择制表符的宽度)

8.find(索引字符的位置,没有返回值为-1)index(同find,但是他查不到会报错)rfind(从右向左查同find)rindex(从右向左返回索引值同index)

9.format(格式化输出)format_map(格式化输出,以字典形式存储kv数据)

people={'name':['Frank','Caroline','jeff'],'age':['23','22'],

}print("My name is {name[2]},i am {age[0]} years old !".format_map(people))

运行结果

My nameis jeff,i am 23 years old !

10.isalnum(是否是数字与字母的组合)isalpha(是否是字母组合)isdecimal(是否是十进制正整数)isdigit(是否是真整数)isdentifier(是否是python中的标识符)islower(判断字符串字母是不是都是小写)isnumeric(是不是数字,无论中文还是其他只要是数字就能判断)isprintable(是否可打印)isspace(是否都是空格,tab/r等)istitle(是否所有字符首字母大写)返回值都是bool值

11.join(以指定字符连接生成新的字符串)

tell = "my name Is jeff"

print('='.join(tell))

运行结果

m=y= =n=a=m=e= =I=s= =j=e=f=f

12.ljust与rjust指定字符宽度填充,与center类似

tell = "my name Is jeff"

print(tell.ljust(20,'='))print(tell.rjust(20,'='))

运行结果

my name Is jeff=====

=====my name Is jeff

13.lstrip,rstrip,strip去前后空白\r\n等

14.maketrans,translate

intab = "abcde"outtab= "12345"tell= "my name Is jeff"trantab=tell .maketrans(intab, outtab)print(tell.translate(trantab))

运行结果

my n1m5 Is j5ff

15.partition(指定分隔字符,返回一个元组里)rpartition(从右向左分割,只分割一次,若没有指定字符返回元祖前面加两个空字符串)split(指定字符分割,可指定分割次数分割后删除指定的字符默认空格分割)rsplit(同split只是从右向左)

16.replace(指定字符替换为新的字符,可指定个数)

17.splitlines(将字符串转换为列表)

18.startswith(是否是字符串或字符开头)

19.swapcase(大小写互换)

20.zfill(与center类似,显示在右边不足宽度补零)

整型与长整型

整型是不包含小数部分的数值,格式是“int”。长整型(无穷精度)与整型(32位)类似只是数字比较大,格式是“type”。且长整型只存在于python2中,32位机器上取值范围是-2**31~2**31-1,在64位机器上取值为-2**63~2**63-1。在python3中没有整型与长整型的区分,只有整型。

浮点型

我们可以简单的把浮点型看做是小数。格式类型是“float”。浮点型除了作为小数输出还常用于科学计数法中。

a=1.23e10b=1.23E10

print(a)print(b)print(type(a))print(type(b))

输出结果12300000000.0

12300000000.0

bool型

bool类型的返回值只有两种:True和False。

逻辑运算:

1.与运算:and(两个都为True,结果才为True)

2.或:or(只要一个为True,则为True)

3.非:not(把True变为False,把False变为True)

短路运算:

布尔类型还可以与其他数据类型进行逻辑运算,python中0、空字符串、None、空列表、空字典等为False,其他数值和非空字符串为True。

1.在计算a and b时,如果a是True,则计算结果取决于b,则返回b;如果a是False,则直接返回a。

2.在计算a or b时,如果a是True,则直接返回a;否则返回b。

bool类型还可以当做整型的0和1使用。

print(True+13) #True为1

print(False+13) #False为0

输出结果14

13

列表

列表是由一系列按特定顺序排列的元素组成。在python中,用方括号表示列表,并用逗号来分割其中的元素,格式类型为“list”。

列表的内置方法有:

1.append(在列表的最后添加某个元素)insert(也是添加元素,但是可以通国索引指定插入具体位置)

2.count(某个元素的个数)

3.clear(清空列表)

4.copy(复制列表)

name = ['jeff','Frank',1,{'xixi':'sabi'},[3,4]]

name_cp=name.copy()print(name_cp)

name[0]='Tom'name[2]= 7

print(name)print(name_cp)

运行结果

['jeff', 'Frank', 1, {'xixi': 'sabi'}, [3, 4]]

['Tom', 'Frank', 7, {'xixi': 'sabi'}, [3, 4]]

['jeff', 'Frank', 1, {'xixi': 'sabi'}, [3, 4]]

注:改变列表name中的元素name.copy中的值也随着变化。但是改变列表name中的列表值,name.copy的列表值是不会变得。由于列表中的列表开辟的空间是不变的(列表本身是可变数据类型)name与name.copy指向的是同一个地址,里面存储的值会一起改变。

5.deepcopy与copy类似,但是无论copy原列表如何变化,deepcopy的列表都会与列表一起变化,即两者指向统一的数据空间。

6.extend(函数用于在列表末尾一次性追加另一个序列中的多个值,用新列表扩展原来的列表。)

name = ['Saber','Frank']

nameto= ['Mei','Jack']

name.extend(nameto)print(name)

运行结果

['Saber', 'Frank', 'Mei', 'Jack']

7.index(查找相应元素的索引值,可指定索引范围并且查不到也不会报错)

8.pop(弹出元素,不指定默认弹出最后一个值,索引失败会报错,弹出的值可以存储到其他列表或变量里。)remove(也是移除,可指定移除的具体元素)del(无敌的移除手段)

9.reverse(将列表中元素反转过来)

10.sort(将列表排序,永久修改可通过reverse=True传递倒着排序)sorted(与sort类似但是不改变原列表的元素)

11.len(查看列表的长度)

元组

与列表很相似,只是不可以进行修改。若是要改变元组中的值只能够改掉整个元组咯。

集合

集合是无需元素组成,打印时顺序也是无序的,但是集合中没有重复的元素,所以我们常使用集合去重。

我们有两个集合a与b:

a与b的交集为a.intersection(b)或者a & b。

a与b的差集为a.difference(b)或者a-b。

a与b的并集为a.union(b)或者a|b。

反向差集与对称差集(并集减去交集)为a.symmetric_difference(b)或者a^b。

合并为a.update(b),a.difference_update(b)求差集并赋值给a集合

删除元素可用discard(元素)或者remove(元素),pop()是随机删除一个元素。

注:set是可变数据类型,但是set里面的元素一定是不可变数据类型。

字典

在python里面,字典就是一系列的键-值对,每个键都与一个值是对应的,键可以是数字、字符串、列表和字典。任何python对象都可用作字典的值。

字典中常用的内置方法有:

keys(取出字典中的key)

values(取出字典中的value)

clear(清空所有键值对)

copy(与列表一致)

fromkeys(创建新的列表所有的值都是同一个value)

key = (1,2,3,4,5)

value= ('a','b','c','d','e')print(dict.fromkeys(key,value))

运行结果

{1: ('a', 'b', 'c', 'd', 'e'), 2: ('a', 'b', 'c', 'd', 'e'), 3: ('a', 'b', 'c', 'd', 'e'), 4: ('a', 'b', 'c', 'd', 'e'), 5: ('a', 'b', 'c', 'd', 'e')}

a = {"k1":123, "k2":456, "k3":789}

b= a.fromkeys(["k1", "k2", "k3"], "876")print(b)#输出 {'k2': '876', 'k3': '876', 'k1': '876'}

get(查找的一种方式,找不到对象返回None)

item(返回键值对)

pop(指定key,弹出此键值对)

popitem(弹出最后一个键值对返回到元组中,没有会报错)

update(将新的字典添加到原来的字典,若原来的字典包含了这个键则覆盖原来的值)

setdefault(k,v)如果键在字典中,则返回这个键的值,如果不在字典中,则向字典中插入这个键,并返回value,默认value位None。

bytes

所有的字符存到存储单元里都是bytes类型。

这里简述了集中python中常用数据类型以及内置的一些使用方法,方便以后对python的学习在此总结一下。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值