亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如何從列表列表創建 Pandas DataFrame?

如何從列表列表創建 Pandas DataFrame?

海綿寶寶撒 2022-01-05 19:55:14
我有一份清單。這是它的一個示例。[[], ['1', 'Anthony Taylor', '6', '11.17', '0.68', '0.17', '1.83', '11', '0.17', '1'], ['2', 'Jonathan Moss', '4', '12.75', '0.73', '0.00', '2.00', '8', '0.00', '0'], ['3', 'Martin Atkinson', '3', '11.00', '0.69', '0.67', '1.67', '5', '0.00', '0'], ['4', 'Graham Scott', '3', '10.00', '0.67', '0.00', '0.33', '1', '0.00', '0'], ['5', 'Chris Kavanagh', '3', '10.33', '0.74', '0.00', '1.67', '5', '0.00', '0'], ['6', 'Michael Oliver', '2', '12.00', '0.62', '1.00', '2.00', '4', '0.00', '0']如何從中創建一個類似于此格式的 Pandas DataFrame(每一行都有一個單獨的名稱)?['1', 'Anthony Taylor', '6', '11.17', '0.68', '0.17', '1.83', '11', '0.17', '1']['2', 'Jonathan Moss', '4', '12.75', '0.73', '0.00', '2.00', '8', '0.00', '0']['3', 'Martin Atkinson', '3', '11.00', '0.69', '0.67', '1.67', '5', '0.00', '0']['4', 'Graham Scott', '3', '10.00', '0.67', '0.00', '0.33', '1', '0.00', '0']['5', 'Chris Kavanagh', '3', '10.33', '0.74', '0.00', '1.67', '5', '0.00', '0']['6', 'Michael Oliver', '2', '12.00', '0.62', '1.00', '2.00', '4', '0.00', '0']['7', 'Paul Tierney', '2', '12.50', '0.66', '0.00', '2.50', '5', '0.00', '0']['8', 'Mike Dean', '2', '14.50', '0.73', '0.50', '3.00', '6', '0.00', '0']['9', 'Andre Marriner', '2', '8.50', '0.53', '0.00', '2.00', '4', '0.00', '0']['10', 'Kevin Friend', '2', '9.50', '0.50', '0.00', '3.00', '6', '0.00', '0']['11', 'Craig Pawson', '1', '9.00', '0.45', '0.00', '1.00', '1', '0.00', '0']['12', 'Stuart Attwell', '1', '9.00', '0.75', '0.00', '2.00', '2', '0.00', '0']['13', 'Lee Probert', '1', '11.00', '0.73', '0.00', '0.00', '0', '0.00', '0']['', 'Total / Average', '32', '11.09', '0.66', '0.19', '1.81', '58', '0.03', '1']在我的研究過程中,這個答案對我有所幫助,但它仍然只將所有內容放入一個列中,而我希望特定列表的每個元素都有一個單獨的列。有什么方法可以實現這一目標嗎?
查看完整描述

2 回答

?
手掌心

TA貢獻1942條經驗 獲得超3個贊

您可以過濾掉第一個子列表并傳遞給 DataFrame 構造函數,也可以通過另一個列表設置列名稱:


L = [[], ['1', 'Anthony Taylor', '6', '11.17', '0.68', '0.17', '1.83', '11', '0.17', '1'], ['2', 'Jonathan Moss', '4', '12.75', '0.73', '0.00', '2.00', '8', '0.00', '0'], ['3', 'Martin Atkinson', '3', '11.00', '0.69', '0.67', '1.67', '5', '0.00', '0'], ['4', 'Graham Scott', '3', '10.00', '0.67', '0.00', '0.33', '1', '0.00', '0'], ['5', 'Chris Kavanagh', '3', '10.33', '0.74', '0.00', '1.67', '5', '0.00', '0'], ['6', 'Michael Oliver', '2', '12.00', '0.62', '1.00', '2.00', '4', '0.00', '0'], ['7', 'Paul Tierney', '2', '12.50', '0.66', '0.00', '2.50', '5', '0.00', '0'], ['8', 'Mike Dean', '2', '14.50', '0.73', '0.50', '3.00', '6', '0.00', '0'], ['9', 'Andre Marriner', '2', '8.50', '0.53', '0.00', '2.00', '4', '0.00', '0'], ['10', 'Kevin Friend', '2', '9.50', '0.50', '0.00', '3.00', '6', '0.00', '0'], ['11', 'Craig Pawson', '1', '9.00', '0.45', '0.00', '1.00', '1', '0.00', '0'], ['12', 'Stuart Attwell', '1', '9.00', '0.75', '0.00', '2.00', '2', '0.00', '0'], ['13', 'Lee Probert', '1', '11.00', '0.73', '0.00', '0.00', '0', '0.00', '0'], ['', 'Total / Average', '32', '11.09', '0.66', '0.19', '1.81', '58', '0.03', '1']]

cols = ['id','name','a','b','c','d','e','f','g','h']

df = pd.DataFrame(L[1:], columns=cols)

print(df)

    id             name   a      b     c     d     e   f     g  h

0    1   Anthony Taylor   6  11.17  0.68  0.17  1.83  11  0.17  1

1    2    Jonathan Moss   4  12.75  0.73  0.00  2.00   8  0.00  0

2    3  Martin Atkinson   3  11.00  0.69  0.67  1.67   5  0.00  0

3    4     Graham Scott   3  10.00  0.67  0.00  0.33   1  0.00  0

4    5   Chris Kavanagh   3  10.33  0.74  0.00  1.67   5  0.00  0

5    6   Michael Oliver   2  12.00  0.62  1.00  2.00   4  0.00  0

6    7     Paul Tierney   2  12.50  0.66  0.00  2.50   5  0.00  0

7    8        Mike Dean   2  14.50  0.73  0.50  3.00   6  0.00  0

8    9   Andre Marriner   2   8.50  0.53  0.00  2.00   4  0.00  0

9   10     Kevin Friend   2   9.50  0.50  0.00  3.00   6  0.00  0

10  11     Craig Pawson   1   9.00  0.45  0.00  1.00   1  0.00  0

11  12   Stuart Attwell   1   9.00  0.75  0.00  2.00   2  0.00  0

12  13      Lee Probert   1  11.00  0.73  0.00  0.00   0  0.00  0

13      Total / Average  32  11.09  0.66  0.19  1.81  58  0.03  1


查看完整回答
反對 回復 2022-01-05
?
心有法竹

TA貢獻1866條經驗 獲得超5個贊

使用pandas.DataFrame.from_records:


import pandas as pd


df = pd.DataFrame.from_records(x[1:]))

print(df)

輸出:


    0                 1   2      3     4     5     6   7     8  9

0    1   Anthony Taylor   6  11.17  0.68  0.17  1.83  11  0.17  1

1    2    Jonathan Moss   4  12.75  0.73  0.00  2.00   8  0.00  0

2    3  Martin Atkinson   3  11.00  0.69  0.67  1.67   5  0.00  0

3    4     Graham Scott   3  10.00  0.67  0.00  0.33   1  0.00  0

4    5   Chris Kavanagh   3  10.33  0.74  0.00  1.67   5  0.00  0

5    6   Michael Oliver   2  12.00  0.62  1.00  2.00   4  0.00  0

6    7     Paul Tierney   2  12.50  0.66  0.00  2.50   5  0.00  0

7    8        Mike Dean   2  14.50  0.73  0.50  3.00   6  0.00  0

8    9   Andre Marriner   2   8.50  0.53  0.00  2.00   4  0.00  0

9   10     Kevin Friend   2   9.50  0.50  0.00  3.00   6  0.00  0

10  11     Craig Pawson   1   9.00  0.45  0.00  1.00   1  0.00  0

11  12   Stuart Attwell   1   9.00  0.75  0.00  2.00   2  0.00  0

12  13      Lee Probert   1  11.00  0.73  0.00  0.00   0  0.00  0

13      Total / Average  32  11.09  0.66  0.19  1.81  58  0.03  1


查看完整回答
反對 回復 2022-01-05
  • 2 回答
  • 0 關注
  • 193 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號