日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程语言 > python >内容正文

python

pythoncsv格式列变换_用Python将csv行转换为列

發(fā)布時(shí)間:2025/3/12 python 51 豆豆
生活随笔 收集整理的這篇文章主要介紹了 pythoncsv格式列变换_用Python将csv行转换为列 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

關(guān)于如何使用zip合并數(shù)據(jù)以及轉(zhuǎn)置列表的一些提示。

這聽(tīng)起來(lái)像是如何轉(zhuǎn)置csv是你真正的問(wèn)題。如何轉(zhuǎn)置csv的答案是將其放入列表列表(例如通過(guò)csv模塊),然后將其轉(zhuǎn)置并寫(xiě)回文件(如果需要)。在row1 = [1,2,3]

row2 = ['a', 'b', 'c']

list(zip(row1, row2))

Out[45]: [(1, 'a'), (2, 'b'), (3, 'c')]

z = list(zip(row1, row2))

list(zip(*z))

Out[47]: [(1, 2, 3), ('a', 'b', 'c')]

y = list(zip(*z))

y

Out[49]: [(1, 2, 3), ('a', 'b', 'c')]

list(zip(*y))

Out[50]: [(1, 'a'), (2, 'b'), (3, 'c')]

或者,如果您安裝了numpy或pandas,這兩種方法都可以在最多3行代碼中使用read_file/transpose_matrix/write_transposed_to_文件

所以根據(jù)你的代碼,我會(huì)讀所有的文件,把它們放在內(nèi)存里,然后再進(jìn)行轉(zhuǎn)置寫(xiě)。我想如果你改變這一部分,它會(huì)成功的(我沒(méi)有親自測(cè)試)。在

^{pr2}$

如果每個(gè)原始文件沒(méi)有嚴(yán)格的1行,那么將得到有趣的結(jié)果。在

更新:

我舉了一個(gè)小例子。在files = list('abcd')

file_rows = [files]

for filename in [range(i, i+4) for i in range(0, 12, 4)]:

tmp_rows = []

fake_csv = [list(filename)]

for row in fake_csv:

tmp_rows += [row] # change to [row, row] to see what happens

# in case of multiple rows in original csv

file_rows += tmp_rows

transposed = list(zip(*file_rows))

print(transposed)

在完成測(cè)試代碼之后,我稍微調(diào)整了一下原始代碼,使其列在列表中,這是唯一的事情。所以,如果你在改變之后仍然得到有趣的結(jié)果,那是因?yàn)槟銢](méi)有統(tǒng)一的輸入數(shù)據(jù),在這種情況下,你需要決定如何處理。例如,zip將靜默地只輸出所有原始行的最短列表的長(zhǎng)度。要修復(fù)此問(wèn)題,您需要以代碼方式添加到,以便所有列表的長(zhǎng)度與最長(zhǎng)的行相同。在

總結(jié)

以上是生活随笔為你收集整理的pythoncsv格式列变换_用Python将csv行转换为列的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。