切片--字符串的倒序輸出:
str[::-1]
s[1:4] 切片工具, 第一個冒號前面的數(shù)字表示從第幾個索引值開始【包含這個值】, 第一個冒號后面表示取到第幾個【索引值,注意,不包含這個值!!】,第二個冒號,后面的表示是否倒序。
list當做一個列表方法。

s =str () 可以把list改為string ,注意這個 時候s是字符串?。?!

但是我當時不會切片工具的 原因就是我沒有粘出來,或者右鍵標識! 結(jié)果就是
但是join可以!!! 用””.join(list)可以拼接
s="abcd" l=list(s) l.reverse() str=str(l)
現(xiàn)在的問題是 str 如何用切片工具 得到dcba
就是一個列表['d', 'c', 'b', 'a'] 如何得到一個字符串,結(jié)論是:str[2::5]
切片工具, 第一個冒號前面的數(shù)字表示從第幾個索引值開始【包含這個值】, 第一個冒號后面表示取到第幾個【索引值,注意,不包含這個值!!】,第二個冒號,后面的表示是否倒序或者間隔幾個來?。?/p>
切片太厲害了
L = range(100)
Python支持L[-1]取倒數(shù)第一個元素,那么取后10個數(shù):
>>> L[-10:] [90, 91, 92, 93, 94, 95, 96, 97, 98, 99]
寫[:]就可以原樣復(fù)制一個list:
L = range(100) b=L[:]
這樣b就是一個全新的b了,不再和L指向同一個列表了?。?!
字符串也可以用切片操作!
'ABCDEFG'[::2]
輸出'ACEG'
迭代、循環(huán)
對于set集合
d = {'a': 1, 'b': 2, 'c': 3} for key in d: print(key)
需要迭代set里面的值,for value in d.itervalues()
要同時迭代key和value,可以用for k, v in d.iteritems()。
如何判斷一個對象是可迭代對象呢?方法是通過collections模塊的Iterable類型判斷:
from collections import Iterable
isinstance('abc', Iterable) # str是否可迭代,得到true
Python內(nèi)置的enumerate函數(shù)可以把一個list變成索引-元素對,這樣就可以在for循環(huán)中同時迭代索引和元素本身:
for i, value in enumerate(['A', 'B', 'C']): print i, value
for循環(huán)里,同時引用了兩個變量,在Python里是很常見的,比如下面的代碼:
e=[[1,1],[2,2]] for x, y in [(1, 1), (2, 4), (3, 9)]: ... print x, y
哇塞?。?# list里面的元素是tuple
列表生成器(需要自己測試)
列表生成式即List Comprehensions,是Python內(nèi)置的非常簡單卻強大的可以用來創(chuàng)建list的生成式。
[x * x for x in range(1, 11)] [1, 4, 9, 16, 25, 36, 49, 64, 81, 100]
寫列表生成式時,把要生成的元素x * x放到前面,后面跟for循環(huán),就可以把list創(chuàng)建出來,十分有用
下面:for循環(huán)后面還可以加上if判斷,這樣我們就可以篩選出僅偶數(shù)的平方:
[x * x for x in range(1, 11) if x % 2 == 0] [4, 16, 36, 64, 100]
還可以使用兩層循環(huán),可以生成全排列:
[m + n for m in 'ABC' for n in 'XYZ'] ['AX', 'AY', 'AZ', 'BX', 'BY', 'BZ', 'CX', 'CY', 'CZ']
例如,列出當前目錄下的所有文件和目錄名,可以通過一行代碼實現(xiàn):
import os # 導(dǎo)入os模塊,模塊的概念后面講到
>>> [d for d in os.listdir('.')] # os.listdir可以列出文件和目錄
列表生成式也可以使用兩個變量來生成list:
d = {'x': 'A', 'y': 'B', 'z': 'C' }
>>> [k + '=' + v for k, v in d.iteritems()]
['y=B', 'x=A', 'z=C']
最后一個把list里面變?yōu)樾?br>
L = ['Hello', 'World', 'IBM', 'Apple']
>>> [s.lower() for s in L]
['hello', 'world', 'ibm', 'apple']
下面利用判斷字符串來寫,厲害了。
L = ['Hello', 'World', 18, 'Apple', None] [s.lower() for s in L if isinstance(s, str)] 這樣不能輸出18 [s.lower() if isinstance(s, str) else s for s in L] 這樣是對的