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

posted @ 2016-04-26 19:59  青茶360  阅读(1568)  评论(0编辑  收藏  举报