Python基本数据类型
一、整数
int(整形)
在32位机器上,整数的位数为32位,取值范围为-2**31~2**1-1,即-2147483648~2147483647
在64位系统上,整数的位数为64位,取值范围为-2**63~2**63-1,即-9223372036854775808~9223372036854775807
def bit_length(self):
'''表示返回该数字的二进制占用的最小位数'''
int.bit_length()-> int
案例:
int_bit = 37 ret = int_bit.bit_length() print(ret)
答案:6
(解释过程){ >>> bin(37) '0b100101' >>> (37).bit_length() 6 """ }
二、字符串的参数(常用功能:移除,分割,长度,索引,切片)
1、def capitalize(self):
'''首字母大写'''
acc = “alex” ret = acc.capitalize() print(ret)
2、def center(self,width,fillchar=None):
'''内容居中,width:总长度;filchar:空白处填充内容,默认无 '''
S.center(width[,fillchar]) -> string
案例一:
al = "acc" ret = al.center(20) print(ret) 结果默认是空格 acc
案例二:
al = "acc" ret = al.center(20,"_") print(ret) 结果:________acc_________
3、def count(self,sub,start=None,end=None):
'''子序列个数'''
s.count(sub[,start[,end]]) -> int
acc = "alexadal" ret = acc.count("al") re = acc.count("al",2,10) print(ret) print(re) 答案:2 1
4、def decode(self,encoding=None,errors=None):
"""解码"""
s.decode([encoding[,errors]]) -> object
案例:
temp = “李杰” temp_unicode = temp.decode(‘utf-8’) 意思是把utf-8解码成unicode
5、def encode(self, encoding=None, errors=None):
"""编码,针对unicode """
S.encode([encoding[,errors]])-> object
案例:
temp.gpk = temp.unicode(‘gbk’)
意思是把unicode在编码成gbk格式
6、def endswith(self,suffix,start=None,end=None):
"""是否以xxx结束"""
s.endswith(suffix[,start[,end]]) ->bool
案例:
name_a = "accp" ret = name_a.endswith("ac",0,2) print(ret) 结果:True
7、def expandtabs(self,tabsize=None):
"""将tab转换成空格,默认一个tab转换成8个空格"""
s.expandgtabs([tabsize]) -> string
案例:
name_b = "this is a \tasdf" ret = name_b.expandtabs() ac = name_b.expandtabs(tabsize=10) print(ret) print(ac) 结果: this is a asdf this is a asdf
8、def find(self,sub,start=None,end=None):
"""寻找子序列位置,如果没有找到,返回 -1"""
s.find(sub[,start[,end]]) -> int
· str -- 查找的字符串
· beg -- 开始查找的位置,默认为0
· end -- 结束查找位置,默认为字符串的长度
案例:
str1 = "this is a string example ... wow" str2 = "exam" print(str1.find(str2)) print(str1.find(str2,10)) print(str1.find(str2,40)) 答案:17 17 -1 ----错误了find参数用-1表示,而index是报错 str = "this is really a string example....wow!!!"; str1 = "is"; print str.rfind(str1, 0, 10);
9、def index(self,sub,start=None,end=None):
"""子序列位置,如果没找到,报错"""
s.index(sub[,start[,end]]) ->int
案例:
str1 = "this is a string example ... wow" str2 = "exam" ret = str1.index("strin",3) print(ret) print(str1.index(str2,10)) 答案:10 17
和find一样,相对应的也有rindex
#!/usr/bin/python3 str1 = "this is really a string example....wow!!!" str2 = "is" print (str1.rindex(str2)) print (str1.rindex(str2,10)) ------------------------------------------ 5 Traceback (most recent call last): File "test.py", line 6, in <module> print (str1.rindex(str2,10)) ValueError: substring not found
10、def format(*args,**kwargs):
"""字符串格式化,动态参数,将函数式编程时细说"""
s.format(*args,**kwargs)-> string
案例:
s = "hello {0},world(1)" print(s) new1 = s.format("alex",19) print(new1) 答案:hello {0},world(1) hello alex,world(1)
案例二、
{name}:将被format()方法中关键字参数name代替 >>> print '{c} {b} {a}'.format(a = 'efhdn', b = 123, c = 8.3 ) 8.3 123 efhdn • {或}:要输出一个{或},必须使用{{或}}格式 >>> print '{{中国}} 你好!'.format() {中国} 你好!
11、def isalnum(slef):
"""是否是字母和数字"""
s.isalnum() ->bool
案例:
str = "this2009"; # No space in this string print str.isalnum(); str = "this is string example....wow!!!"; print str.isalnum(); 答案: True False
12、def isalpha(self):
"""是否是字母"""
s.isalpha()-> bool
13、def isdigit(self):
"""是否是数字"""
s.isdigit() -> bool
14、def islower(self):
"""是否小写"""
s.islower()-> bool
15、def isspace(self):
"""是否只包含空格"""
s.isapce() -> bool
案例:
str = " "; print str.isspace(); str = "This is string example....wow!!!"; print str.isspace();
16、def istitle(self):
"""检测字符串中所有的单词拼写首字母是否为大写,且其他字母为小写返回True,否则为False"""
a = “This Is A Sjsd”
a.istitle() à bool
17、def isupper(self):
"""检测字符串是否为大写"""
s.isupper() -> bool
18、def join(self,itearble):
"""连接"""
s.join(iterable) -> string
案例:
str1 = "_*" str2 = ("a","b","c") ret = str1.join(str2) print(ret) 答案:a_*b_*c
19、def ljust(self,width,fillchar=None):
"""内容左对齐,右侧填充"""
s.ljust(width[,fillchar]) -> string
width ----指定字符串长度
fillchar----填充字符,默认为空格
案例:
str = “this is sting exaple…wow” ret = str.ljust(30,’*’) #注意这个的fillchar要加引号,引起来 print(ret) 答案: this is sting exaple…wow******* 相对应的有函数rjust(右对齐,左填充),方法一样 zfill也一样 def zfill(self, width): """方法返回指定长度的字符串,原字符串右对齐,前面填充0。""" S.zfill(width) -> string
20、def lower(self):
"""变小写"""
s.lower() -> string
案例:
str_name1 = "MY NAME IS damon" print(str_name1.lower()) 答案: my name is damon 相对应的是upper““变大写” up = "this is string example ...wow" ret = up.upper() print(ret) 答案 THIS IS STRING EXAMPLE ...WOW
21、def partitiong(self,sep):
”””分割,前,中,后三部分”""
s.partition(sep) -> (head,sep,tail)
案例:
str_name1 = "MY NAME IS domen" ret = str_name1.partition("IS") print(ret) 答案: ('MY NAME ', 'IS', ' domen')
22、def lstrip(self,chars=None):
“””移除左侧空白”””
s.lstrip([chars]) -> string or unicode
chars 表示指定截取的字符
案例:
str_name2 = " this is a string wow ...." print(str_name2.lstrip()) str_name3 = "88888this is a string wow ... 888" print(str_name3.lstrip("88888this")) 答案: this is a string wow .... is a string wow ... 888
23、def replace(self,old,new,coubt=None):
“”””替换””
s.replace(old,new[,count]) -> int
s.replace(old,new[,count]) -> int
s.replace(old,new[,count]) -> int
old 将被替换的子字符串
new 新字符串,用于替换old子字符串
max 可选字符串,替换不超过max次
案例:
str_name3 = "this is a example wow,this is a really example,is" ret = str_name3.replace("is","si",2) print(ret) 答案: thsi si a example wow,this is a really example,is
24、def split(self,sep=None,maxsplit=None): _—————与join相反(join是连接)
“””分割,maxsplit最多分割几次”””
s.split([sep[,maxsplit]]) -> list of strings
str – 分隔符,默认为空格
num – 分割次数
案例:
str = "Line1-abcdef \nLine2-abc \nLine4-abcd"; print(str.split( )) print(str.split(' ', 1 )) print(str) 答案: ['Line1-abcdef', 'Line2-abc', 'Line4-abcd'] ['Line1-abcdef', '\nLine2-abc \nLine4-abcd'] Line1-abcdef Line2-abc Line4-abcd
25、def splitlines(self,keepends=False):
“””根据换行分割”””
S.splitlines(keepends=False) -> list of strings
案例:
str_name5 = "this is a example wow \n yes,zhis is \n\n\n\n i don't" print(str_name5.splitlines(3)) 答案: ['this is a example wow \n', ' yes,zhis is \n', '\n', '\n', '\n', " i don't"]
26、def startswith(self,prefix,start=None,end=None):
“””是否起始”””
S.startswith(prefix[,start[,end]]) -> bool
案例:
str = "i like you " ret = str.startswith("i",0,4) print(ret) 答案:True
27、def strip(self,chars=None):
“””移除两段空白”””
S.strip([chars]) -> string or unicode
案例:
str = "*****this is string example....wow!!!*****" print (str.strip( '*' )) 答案: this is string example....wow!!!
28、def swapcase(self):
“”大写变小写,小写变大写””
S.swapcase() -> string
案例:
bxx = "THIS IS A EXSMPLE.." ret = bxx.swapcase() print(ret) 答案: this is a exsmple..
29、def title(self):
“””开头首字母变大写”””
S.title() -> string
案例:
tit = "THIS IS A EXSMPLE.." ret = tit.title() print(ret) 答案: This Is A Exsmple..
30、def translate(self,table,deletachars=None):--3.0没有deletachars这个参数了
“转换需要先做一个对应表,最后一个表示删除字符集合”
- table -- 翻译表,翻译表是通过maketrans方法转换而来。
- deletechars -- 字符串中要过滤的字符列表。
S.translate(table[,deletechars]) -> string
案例:
intab = "aeiou" outab = "12345" transtab = str.maketrans(intab,outab) str = "this is a string example ... wow" ret = str.translate(transtab) print(ret) 答案: th3s 3s 1 str3ng 2x1mpl2 ... w4w
知识小点:
maketrans() 方法用于创建字符映射的转换表,对于接受两个参数的最简单的调用方式,第一个参数是字符串,表示需要转换的字符,第二个参数也是字符串表示转换的目标。
注:两个字符串的长度必须相同,为一一对应的关系。
maketrans用法
str.maketrans(intab,outab)
参数:
intab – 字符串中药代替的字符组合的字符串
outab – 相应的映射字符的字符串
三、列表(基本操作:索引,切片,追加,删除,长度,切片,循环,包含)
创建列表:name_list = [‘alex’,’serven’,’eric’]
或 name_list = list([‘alex’,’serven’,’eric’])
1、 def append(self,p_object):
“”末尾添加””
语法:L.append(object) -----obj—添加到列表末尾的对象
案例:
list1 = ['google','baidu','nunoob'] list2= list1.append('tengxun') print("更新后的列表 ",list1)#注:list2已经执行添加到了列表,打印出来肯定为空 答案: 更新后的列表 ['google', 'baidu', 'nunoob', 'tengxun']
2、def count(self,value):
“”统计某个元素在列表中出现的次数””
语法:list.count(obj) ---obj—列表中统计的对象
案例:
alist = [123,'xyz','zara','abc'] print('次数',alist.count(123)) print('次数:',alist.count('xyz')) 答案: 次数 1 次数: 1
3、def extend(self,iterable): 新单词extend(扩展)
“””用于在列表末尾一次性追加另一个列表中的多个值(用新列表扩展原来的列表)”””
语法:list.extend(seq---元素列表)
案例:
list1 = ['google','runoob','taobao'] list2 = list(range(5)) list1.extend(list2) print('扩展后的列表:',list1) 答案: 扩展后的列表: ['google', 'runoob', 'taobao', 0, 1, 2, 3, 4]
4、def index(self):
“””用于从列表中找出某个值第一个匹配项的索引位置”””
语法:list.index(obj—查找的对象)
案例:
alist = [123,'xyz','zara','abc'] print("Index for xyz:",alist.index('xyz')) print('Index for zara',alist.index('zara')) 答案: Index for xyz: 1 Index for zara: 2
5、def insert(self,index,p_object):
“””函数将用于指定对象charu 列表”””
语法:list.insert(index,obj)
index,对象obj需要插入的索引位置
obj,要出入列表中的对象
案例:
list1 = ['google','baidu','ali'] list1.insert(1,'lol') print('列表插入元素后:',list1) 答案: 列表插入元素后: ['google', 'lol', 'baidu', 'ali']
6、def pop(self,index=None):
“””用于移除列表中的一个元素(默认最后一个元素)”””
语法:list.pop(obj=list[-1])
案例:
list1 = ['google','baidu','ali'] list1.pop() print(list1) list1.pop(-1) print(list1) 答案: list1 = ['google','baidu','ali'] list1.pop() print(list1) list1.pop(-1) print(list1)
7、def remove(self,value)
“””用于移除列表中的某个值的第一个匹配项”””
语法:list.remove(obj)
案例:
list_rm = ['google','baidu','ali'] list_rm.remove('google') print(list_rm)
8、def reverse(self):
“””用于反向列表中的元素”””
语法:list.reverse()
案例:
list1 = ['baidu','google','ali','tengx'] list1.reverse() print('见证奇迹的时刻:',list1)
9、def sort(self,cmp=None,key=None,reverse=False):
“””用于对原列表进行排序,如果指定参数,则使用比较函数指定的比较函数”””
语法:list.sort([func])
func ---可选参数,如果指定了该参数会使用该参数的方法进行排序
案例:
list1 = ['ali','Ali','Google','BAIDU','12'] list1.sort() print(list1) 结果:
四、元组(tuple)
基本操作:索引、切片、循环、长度、包含
创建元组:
ages = (11,22,33,44,55)
或
ages = tuple((11,22,33,44,55))
内置函数:count和index
案例:
tup_1 = (11,22,33) print(tup_1.count(33)) print(tup_1.index(22)) 答案:1 1
五、字典
1、clear
“”“用于删除字典内的所有元素”“”
语法:dict.clear()
案例:
dict = {'name':'zara','age':7} print('start len:%d' % len(dict)) dict.clear() print('start len :%d' % len(dict)) 答案: start len:2 start len :0
2、get
“”“函数返回指定键的值,如果值不在字典中返回默认值”“”
语法:dict.get(key,default=None)
参数:key ---字典中要查找的键
default – 如果指定键的值不存在时,返回该默认值
案例:
dict = {'google':'am','baidu':'chi','ali':'chi'} print("值为:%s" % dict.get('google')) print("值为:%s" % dict.get('yutube','em'))---如果字典中没有则添加 答案:值为:am 值为:em
3、in
“in操作符用于判断是否存在于字典中,如果键在字典dict里返回True,否则返回False”
语法:key in dict
案例:
dict = {'name':'alex','age':'18'} ke = 'age' kee = 'max' if ke in dict: print("age的值存在") else: print("age的值不存在") if max in dict: print('max的值存在') else: print('max的值不存在') 答案: age的值存在 max的值不存在
4、keys
”“”python字典keys()方法以列表返回一个字典所有的键“”“
语法:dict.keys()
dict ={'name':'runoob','age':'3'} dict2 = dict.keys() print(dict2) 答案: dict_keys(['name', 'age'])
5、pop
“”“同list一样,删除”“
dict = {'name':'runoob','age':'3'} dict2 = dict.pop('age') print(dict2) print(dict) 答案:3 {'name': 'runoob'}
7、uptade
”“”函数把字典dict2的键/值对更新到dict里(前面)“”“
语法:dict.update(dict2)
案例:
dict = {'name':'alex','age':'3'} dict2 = {'max':'man'} dict.update(dict2) print('更新后的字典:',dict) 答案: {'max': 'man', 'name': 'alex', 'age': '3'}
出处:http://www.cnblogs.com/renfanzi/
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接。