csv.reader(csvfile, dialect='excel', **fmtparams)的一個坑:
csvfile被csv.reader生成的iterator,在周遊每二次時,内容為空
iterator
輸出:
doc demo:
https://docs.python.org/2/library/csv.html#csv-examples
https://docs.python.org/2.7/tutorial/datastructures.html#dictionaries
https://docs.python.org/2.7/library/stdtypes.html#bltin-file-objects
相關知識點:
字元串格式化 (%操作符)
模闆
格式化字元串時,Python使用一個字元串作為模闆。模闆中有格式符,這些格式符為真實值預留位置,并說明真實數值應該呈現的格式。Python用一個tuple将多個值傳遞給模闆,每個值對應一個格式符。
比如下面的例子:
print("I'm %s. I'm %d year old" % ('Vamei', 99))
上面的例子中,
"I'm %s. I'm %d year old" 為我們的模闆。%s為第一個格式符,表示一個字元串。%d為第二個格式符,表示一個整數。('Vamei', 99)的兩個元素'Vamei'和99為替換%s和%d的真實值。
在模闆和tuple之間,有一個%号分隔,它代表了格式化操作。
整個"I'm %s. I'm %d year old" % ('Vamei', 99) 實際上構成一個字元串表達式。我們可以像一個正常的字元串那樣,将它指派給某個變量。比如:
a = "I'm %s. I'm %d year old" % ('Vamei', 99)
print(a)
我們還可以用詞典來傳遞真實值。如下:
print("I'm %(name)s. I'm %(age)d year old" % {'name':'Vamei', 'age':99})
可以看到,我們對兩個格式符進行了命名。命名使用()括起來。每個命名對應詞典的一個key。
格式符
格式符為真實值預留位置,并控制顯示的格式。格式符可以包含有一個類型碼,用以控制顯示的類型,如下:
%s 字元串 (采用str()的顯示)
%r 字元串 (采用repr()的顯示)
%c 單個字元
%b 二進制整數
%d 十進制整數
%i 十進制整數
%o 八進制整數
%x 十六進制整數
%e 指數 (基底寫為e)
%E 指數 (基底寫為E)
%f 浮點數
%F 浮點數,與上相同
%g 指數(e)