Python基本数据类型

一、整数

int(整形)

      在32位机器上,整数的位数为32位,取值范围为-2**31~2**1-1,即-21474836482147483647
在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  
 """  
}  


二、字符串的参数(常用功能:移除,分割,长度,索引,切片)

 

1def capitalize(self):

  '''首字母大写'''

案例:
acc = “alex”  
ret = acc.capitalize()  
print(ret)  

2def 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_________  

3def 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  

4def  decode(self,encoding=None,errors=None)

  """解码"""

  s.decode([encoding[,errors]])  -> object

案例:

temp = “李杰”  
temp_unicode = temp.decode(‘utf-8’)  
意思是把utf-8解码成unicode  

5def  encode(self, encoding=None, errors=None): 

 """编码,针对unicode """

S.encode([encoding[,errors]])-> object

案例:

temp.gpk = temp.unicode(‘gbk’)

意思是把unicode在编码成gbk格式

6def  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  

7def  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  

8def  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);  

9def indexself,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  

10def 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()  
        {中国} 你好!  

11def  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  

 

12def  isalpha(self):

  """是否是字母"""

  s.isalpha()-> bool

13def  isdigit(self):

  """是否是数字"""

  s.isdigit() -> bool

14def  islower(self):

   """是否小写"""

   s.islower()-> bool

15def  isspace(self):

   """是否只包含空格"""

 s.isapce() -> bool

案例:

str = "       ";   
print str.isspace();  
  
str = "This is string example....wow!!!";  
print str.isspace();  

16def  istitle(self):

  """检测字符串中所有的单词拼写首字母是否为大写,且其他字母为小写返回True,否则为False"""

  a = “This Is A Sjsd”

  a.istitle()  à bool

17def  isupper(self):

  """检测字符串是否为大写"""

  s.isupper() -> bool

18def  join(self,itearble):

  """连接"""

  s.join(iterable) -> string

案例:

str1 = "_*"  
str2 = ("a","b","c")  
ret = str1.join(str2)  
print(ret)  
答案:a_*b_*c  

19def  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  

20def  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  

21def  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')  

22def  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  

23def  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  

24def   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

25def  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"]  

26def   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  

27def   strip(self,chars=None):

“””移除两段空白”””

S.strip([chars]) -> string or unicode

案例:

    str = "*****this is string example....wow!!!*****"  
    print (str.strip( '*' ))  
    答案:  
    this is string example....wow!!!  

28def   swapcase(self):

“”大写变小写,小写变大写””

S.swapcase() -> string

案例:

    bxx = "THIS IS A EXSMPLE.."  
    ret = bxx.swapcase()  
    print(ret)  
    答案:  
    this is a exsmple..  

29def   title(self):

“””开头首字母变大写”””

S.title() -> string

案例:

    tit = "THIS IS A EXSMPLE.."  
    ret = tit.title()  
    print(ret)  
    答案:  
    This Is A Exsmple..  

30def   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]  

4def  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 

5def  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']  

6def   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)  

7def  remove(self,value)

“””用于移除列表中的某个值的第一个匹配项”””

语法:list.remove(obj)

案例:

    list_rm = ['google','baidu','ali']  
    list_rm.remove('google')  
    print(list_rm)  

8def   reverse(self):

“””用于反向列表中的元素”””

语法:list.reverse()

案例:

    list1 = ['baidu','google','ali','tengx']  
    list1.reverse()  
    print('见证奇迹的时刻:',list1)  

9def   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  

五、字典

1clear

“”“用于删除字典内的所有元素”“”

语法: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  

2get

“”“函数返回指定键的值,如果值不在字典中返回默认值”“”

语法: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  

3in

“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的值不存在

4keys

”“”python字典keys()方法以列表返回一个字典所有的键“”“

语法:dict.keys()

   dict ={'name':'runoob','age':'3'}  
    dict2 = dict.keys()  
    print(dict2)  
    答案:  
    dict_keys(['name', 'age'])  

5pop

“”“同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'}  

 

 

 

 

 

posted @ 2016-06-27 09:27  我当道士那儿些年  阅读(704)  评论(0编辑  收藏  举报