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

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

具有 2 種不同數據類型的結構化 numpy 數組

具有 2 種不同數據類型的結構化 numpy 數組

千巷貓影 2023-06-27 13:38:16
我將 csv 文件導入到 numpy 數組中,需要將其轉換為結構化數組,其中僅第一列作為 dtype 字符串,所有其他 47 列作為 float。如何在單個操作中定義其他 47 列的數據類型?我是否必須逐列指定 dtype?
查看完整描述

1 回答

?
繁華開滿天機

TA貢獻1816條經驗 獲得超4個贊

您可以像結構化數組一樣讀取源文件。

假設您輸入的文件包含:

  • 一個字符串字段,命名為Id

  • 只有四個 浮點字段,分別命名為F1F2等。

所以它的內容是:

ABCD,160.72,180.21,260.13,451.48

EFGH,252.42,132.21,150.11,612.56

IJKL,541.77,455.21,268.76,543.81

要讀取這樣的文件,您可以使用np.loadtxt方法,將dtype作為結構化類型(定義列表)傳遞,可以在列表理解中生成:


nFloats = 4

a = np.loadtxt('Input.csv', delimiter=',',

    dtype=[('Id', 'U10')] + [( f'F{i+1}', '<f4' ) for i in range(nFloats)])

請注意,我傳遞了U10作為Id列的類型(10 個字符)。如果需要,請設置該字段的其他大小。


結果是:


array([('ABCD', 160.72, 180.21, 260.13, 451.48),

       ('EFGH', 252.42, 132.21, 150.11, 612.56),

       ('IJKL', 541.77, 455.21, 268.76, 543.81)],

      dtype=[('Id', '<U10'), ('F1', '<f4'), ('F2', '<f4'), ('F3', '<f4'), ('F4', '<f4')])

當然,在代碼的目標版本中相應地增加nFloats(可能應該是47)。


查看完整回答
反對 回復 2023-06-27
  • 1 回答
  • 0 關注
  • 99 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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