zoukankan      html  css  js  c++  java
  • Python 列表(list)、字典(dict)、字符串(string)常用基本操作小结

    创建列表  
    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)  
    

      

    python3.0以上,print函数应为print(),不存在dict.iteritems()这个函数。

    在python中写中文注释会报错,这时只要在头部加上# coding=gbk即可

    #字典的添加、删除、修改操作
    dict = {"a" : "apple", "b" : "banana", "g" : "grape", "o" : "orange"}
    dict["w"] = "watermelon"
    del(dict["a"])
    dict["g"] = "grapefruit"
    print dict.pop("b")
    print dict
    dict.clear()
    print dict
    #字典的遍历
    dict = {"a" : "apple", "b" : "banana", "g" : "grape", "o" : "orange"}
    for k in dict:
        print "dict[%s] =" % k,dict[k]
    #字典items()的使用
    dict = {"a" : "apple", "b" : "banana", "c" : "grape", "d" : "orange"}
    #每个元素是一个key和value组成的元组,以列表的方式输出
    print dict.items()
    #调用items()实现字典的遍历
    dict = {"a" : "apple", "b" : "banana", "g" : "grape", "o" : "orange"}
    for (k, v) in dict.items():
        print "dict[%s] =" % k, v
    #调用iteritems()实现字典的遍历
    dict = {"a" : "apple", "b" : "banana", "c" : "grape", "d" : "orange"}
    print dict.iteritems()
    for k, v in dict.iteritems():
        print "dict[%s] =" % k, v
    for (k, v) in zip(dict.iterkeys(), dict.itervalues()):
        print "dict[%s] =" % k, v
       
    #使用列表、字典作为字典的值
    dict = {"a" : ("apple",), "bo" : {"b" : "banana", "o" : "orange"}, "g" : ["grape","grapefruit"]}
    print dict["a"]
    print dict["a"][0]
    print dict["bo"]
    print dict["bo"]["o"]
    print dict["g"]
    print dict["g"][1]
     
    dict = {"a" : "apple", "b" : "banana", "c" : "grape", "d" : "orange"}
    #输出key的列表
    print dict.keys()
    #输出value的列表
    print dict.values()
    #每个元素是一个key和value组成的元组,以列表的方式输出
    print dict.items()
    dict = {"a" : "apple", "b" : "banana", "c" : "grape", "d" : "orange"}
    it = dict.iteritems()
    print it
    #字典中元素的获取方法
    dict = {"a" : "apple", "b" : "banana", "c" : "grape", "d" : "orange"}
    print dict
    print dict.get("c", "apple")         
    print dict.get("e", "apple")
    #get()的等价语句
    D = {"key1" : "value1", "key2" : "value2"}
    if "key1" in D:
        print D["key1"]
    else:
        print "None"
    #字典的更新
    dict = {"a" : "apple", "b" : "banana"}
    print dict
    dict2 = {"c" : "grape", "d" : "orange"}
    dict.update(dict2)
    print dict
    #udpate()的等价语句
    D = {"key1" : "value1", "key2" : "value2"}
    E = {"key3" : "value3", "key4" : "value4"}
    for k in E:
        D[k] = E[k]
    print D
    #字典E中含有字典D中的key
    D = {"key1" : "value1", "key2" : "value2"}
    E = {"key2" : "value3", "key4" : "value4"}
    for k in E:
        D[k] = E[k]
    print D
    #设置默认值
    dict = {}
    dict.setdefault("a")
    print dict
    dict["a"] = "apple"
    dict.setdefault("a","default")
    print dict
    #调用sorted()排序
    dict = {"a" : "apple", "b" : "grape", "c" : "orange", "d" : "banana"}
    print dict  
    #按照key排序 
    print sorted(dict.items(), key=lambda d: d[0])
    #按照value排序 
    print sorted(dict.items(), key=lambda d: d[1])
    #字典的浅拷贝
    dict = {"a" : "apple", "b" : "grape"}
    dict2 = {"c" : "orange", "d" : "banana"}
    dict2 = dict.copy()
    print dict2

  • 相关阅读:
    如何选择合适的开源消息中间件
    使用Rest访问Redis中的数据
    论消息队列在分布式系统的重要性
    grub-install: warning: this GPT partition label contains no BIOS Boot Partition; embedding won’t be possible Ubuntu使用BIOS启动时, GPT分区表下安装grub2报错 的解决办法
    Linux Ubuntu 16.04 启动后 桌面崩溃
    Linux Ubuntu 1604 grub2 rescue mod 启动
    EF自动探测更改
    C# 使用OracleParameter传递参数提示缺少表达式
    Gitlab安装后 500 错误 PostGre数据库无法启动
    DevExpress GridControl GridView多选状态下,代码赋值FocusedRowHandle,样式无变化
  • 原文地址:https://www.cnblogs.com/lazb/p/5436388.html
Copyright © 2011-2022 走看看