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 name is jeff
print('my name is {name}'.format(name='jeff'))
运行结果
my name is 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 name is 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.23e10
b=1.23E10
print(a)
print(b)
print(type(a))
print(type(b))
输出结果
12300000000.0
12300000000.0
<class 'float'>
<class 'float'>

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的学习在此总结一下。

posted @ 2017-07-03 22:51  JeffD  阅读(540)  评论(0编辑  收藏  举报