Home >  > Python 字符串、元组、列表、字典、集合总结

Python 字符串、元组、列表、字典、集合总结

0

(1)字符串

这个没有什么好说的,在Python中以单引号或者双引号包围起来。

(2)列表

什么是列表呢?我觉得列表就是我们日常生活中经常见到的清单。比如,统计过去一周我们买过的东西,把这些东西列出来,就是清单。由于我们买一种东西可能不止一次,所以清单中是允许有重复项的。如果我们扩大清单的范围,统计我们过去一周所有的花费情况,那么这也是一个清单,但这个清单里会有类别不同的项,比如我们买东西是一种花费,交水电费也是一种花费,这些项的类型是可以使不同的。python的列表个跟清单的道理是一样的,特点就是:可重复,类型可不同。类型不同也是跟数组最本质的区别了。python里的列表用“[]”表示。

(3)元组

元组和列表在结构上没有什么区别,唯一的差异在于元组是只读的,不能修改。元组用“()”表示。

(4)集合

集合就是我们数学学的集合,没有什么特殊的定义。集合最好的应用是去重。集合没有特殊的表示方法,而是通过一个set函数转换成集合,如:

lst = [ 1, 1, 0]

lst_set = set( lst )  #lst_set 为1 , 0

tup = (2, 2, 1)

tup_set = set( tup)   # tup_set为2 , 1

for item in lst_set:

print item

5、字典

字典最外面用大括号,每一组用冒号连起来,然后各组用逗号隔开。

在其他语言中也称为map,使用键-值(key-value)存储,字典最大的价值是查询,通过键,查找值。

举个例子,假设要根据同学的名字查找对应的成绩,如果用list实现,需要两个list:

names = ['Michael', 'Bob', 'Tracy']
scores = [95, 75, 85]

如果用dict实现,只需要一个“名字”-“成绩”的对照表,直接根据名字查找成绩,无论这个表有多大,查找速度都不会变慢。

为什么dict查找速度这么快?因为dict的实现原理和查字典是一样的。假设字典包含了1万个汉字,我们要查某一个字,一个办法是把字典从第一页往后翻,直到找到我们想要的字为止,这种方法就是在list中查找元素的方法,list越大,查找越慢。

第二种方法是先在字典的索引表里(比如部首表)查这个字对应的页码,然后直接翻到该页,找到这个字,无论找哪个字,这种查找速度都非常快,不会随着字典大小的增加而变慢。

dict就是第二种实现方式

字典的每个键值(key=>value)对用冒号(:)分割,每个对之间用逗号(,)分割,整个字典包括在花括号({})中 ,格式如下所示:

d = {key1 : value1, key2 : value2 }

也可以写成这样的形式。

 d = {

 'Adam': 95, #key : value

 'Lisa': 85,

 'Bart': 59

 }

它们的基本操作:

    创建列表  
    sample_list = ['a',1,('a','b')]  
      
    Python 列表操作  
    sample_list = ['a','b',0,1,3]  
      
    得到列表中的某一个值  
    value_start = sample_list[0]  
    end_value = sample_list[-1]  
      
    删除列表的第一个值  
    del sample_list[0]  
      
    在列表中插入一个值  
    sample_list[0:0] = ['sample value']  
      
    得到列表的长度  
    list_length = len(sample_list)  
      
    列表遍历  
    for element in sample_list:  
        print 'element'   
          
    Python 列表高级操作/技巧  
      
    产生一个数值递增列表  
    num_inc_list = range(30)  
    #will return a list [0,1,2,...,29]  
      
    用某个固定值初始化列表  
    initial_value = 0  
    list_length = 5  
    sample_list = [ initial_value for i in range(10)]  
    sample_list = [initial_value]*list_length  
    # sample_list ==[0,0,0,0,0]  
      
      
    附:python内置类型  
    1、list:列表(即动态数组,C++标准库的vector,但可含不同类型的元素于一个list中)  
    a = ["I","you","he","she"]      #元素可为任何类型。  
      
    下标:按下标读写,就当作数组处理  
    以0开始,有负下标的使用  
    0第一个元素,-1最后一个元素,  
    -len第一个元素,len-1最后一个元素  
    取list的元素数量                  
    len(list)   #list的长度。实际该方法是调用了此对象的__len__(self)方法。   
      
    创建连续的list  
    L = range(1,5)      #即 L=[1,2,3,4],不含最后一个元素  
    L = range(1, 10, 2) #即 L=[1, 3, 5, 7, 9]  
      
    list的方法  
    L.append(var)   #追加元素  
    L.insert(index,var)  
    L.pop(var)      #返回最后一个元素,并从list中删除之  
    L.remove(var)   #删除第一次出现的该元素  
    L.count(var)    #该元素在列表中出现的个数  
    L.index(var)    #该元素的位置,无则抛异常   
    L.extend(list)  #追加list,即合并list到L上  
    L.sort()        #排序  
    L.reverse()     #倒序  
    list 操作符:,+,*,关键字del  
    a[1:]       #片段操作符,用于子list的提取  
    [1,2]+[3,4] #为[1,2,3,4]。同extend()  
    [2]*4       #为[2,2,2,2]  
    del L[1]    #删除指定下标的元素  
    del L[1:3]  #删除指定下标范围的元素  
    list的复制  
    L1 = L      #L1为L的别名,用C来说就是指针地址相同,对L1操作即对L操作。函数参数就是这样传递的  
    L1 = L[:]   #L1为L的克隆,即另一个拷贝。  
              
    list comprehension  
       [ <expr1> for k in L if <expr2> ]  
                      
    2、dictionary: 字典(即C++标准库的map)  
    dict = {'ob1':'computer', 'ob2':'mouse', 'ob3':'printer'}  
    每一个元素是pair,包含key、value两部分。key是Integer或string类型,value 是任意类型。  
    键是唯一的,字典只认最后一个赋的键值。  
      
    dictionary的方法  
    D.get(key, 0)       #同dict[key],多了个没有则返回缺省值,0。[]没有则抛异常  
    D.has_key(key)      #有该键返回TRUE,否则FALSE  
    D.keys()            #返回字典键的列表  
    D.values()          #以列表的形式返回字典中的值,返回值的列表中可包含重复元素  
    D.items()           #将所有的字典项以列表方式返回,这些列表中的每一项都来自于(键,值),但是项在返回时并没有特殊的顺序           
      
    D.update(dict2)     #增加合并字典  
    D.popitem()         #得到一个pair,并从字典中删除它。已空则抛异常  
    D.clear()           #清空字典,同del dict  
    D.copy()            #拷贝字典  
    D.cmp(dict1,dict2)  #比较字典,(优先级为元素个数、键大小、键值大小)  
                        #第一个大返回1,小返回-1,一样返回0  
                  
    dictionary的复制  
    dict1 = dict        #别名  
    dict2=dict.copy()   #克隆,即另一个拷贝。  
      
    3、tuple:元组(即常量数组)  
    tuple = ('a', 'b', 'c', 'd', 'e')  
    可以用list的 [],:操作符提取元素。就是不能直接修改元素。  
      
    4、string:     字符串(即不能修改的字符list)  
    str = "Hello My friend"  
    字符串是一个整体。如果你想直接修改字符串的某一部分,是不可能的。但我们能够读出字符串的某一部分。  
    子字符串的提取  
    str[:6]  
    字符串包含判断操作符:in,not in  
    "He" in str  
    "she" not in str  
      
    string模块,还提供了很多方法,如  
    S.find(substring, [start [,end]]) #可指范围查找子串,返回索引值,否则返回-1  
    S.rfind(substring,[start [,end]]) #反向查找  
    S.index(substring,[start [,end]]) #同find,只是找不到产生ValueError异常  
    S.rindex(substring,[start [,end]])#同上反向查找  
    S.count(substring,[start [,end]]) #返回找到子串的个数  
      
    S.lowercase()  
    S.capitalize()      #首字母大写  
    S.lower()           #转小写  
    S.upper()           #转大写  
    S.swapcase()        #大小写互换  
      
    S.split(str, ' ')   #将string转list,以空格切分  
    S.join(list, ' ')   #将list转string,以空格连接  
      
    处理字符串的内置函数  
    len(str)                #串长度  
    cmp("my friend", str)   #字符串比较。第一个大,返回1  
    max('abcxyz')           #寻找字符串中最大的字符  
    min('abcxyz')           #寻找字符串中最小的字符  
      
    string的转换  
                  
    float(str) #变成浮点数,float("1e-1")  结果为0.1  
    int(str)        #变成整型,  int("12")  结果为12  
    int(str,base)   #变成base进制整型数,int("11",2) 结果为2  
    long(str)       #变成长整型,  
    long(str,base)  #变成base进制长整型,  
      
    字符串的格式化(注意其转义字符,大多如C语言的,略)  
    str_format % (参数列表) #参数列表是以tuple的形式定义的,即不可运行中改变  
    >>>print ""%s's height is %dcm" % ("My brother", 180)  
              #结果显示为 My brother's height is 180cm  
      
    。。。。。。。。。。。。。。。。。。  
      
    list 和 tuple 的相互转化  
      
    tuple(ls)   
    list(ls)  

暧昧帖

本文暂无标签

发表评论

*

*