[問題] json 與 dataframe 互轉排序問題

看板Python作者 (八八里阿巴)時間8年前 (2017/11/28 15:47), 編輯推噓5(5024)
留言29則, 5人參與, 8年前最新討論串1/1
我有一個 csv 檔, 使用 json 轉換後再轉換回來後發現它會自動幫我把行列做排序, 但是我想維持原本的欄位順序, 請問我該怎麼處理? https://imgur.com/a/0KTnp 附圖最左為我原始csv檔案,中跟右為轉換後行列排序被打亂的csv (希望轉換過後重新輸出的csv還是能跟最左一樣) 以下為我的 code: import json import pandas from pandas.io.json import json_normalize dataFrame_Price = pandas.read_csv(r"C:\price.csv") dataFrame_Price = dataFrame_Price.set_index("ItemName") Jstr_Price = dataFrame_Price.to_json() data = pandas.read_json(Jstr_Price) data.to_csv(r"Result.csv") print data -- ※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 218.161.90.15 ※ 文章網址: https://www.ptt.cc/bbs/Python/M.1511855244.A.A58.html

11/28 15:56, 8年前 , 1F
純粹問一下 為什麼欄位順序這麼重要? csv或json其實都
11/28 15:56, 1F

11/28 15:56, 8年前 , 2F
可以用dict方式load進來讀值 尤其你有column name 更方
11/28 15:56, 2F

11/28 15:56, 8年前 , 3F
便
11/28 15:56, 3F

11/28 16:19, 8年前 , 4F
我只是好奇為什麼順序會被打亂,是因為它有預設什麼參數
11/28 16:19, 4F

11/28 16:20, 8年前 , 5F
我不知道的嗎?另外T大可以請教你用 column name 的方法是
11/28 16:20, 5F

11/28 16:20, 8年前 , 6F
是指什麼意思嗎?因為我現在的方法是為了要把很多個像這
11/28 16:20, 6F

11/28 16:21, 8年前 , 7F
樣的csv檔,傳到一個空間,但是此空間只接受字串,所以
11/28 16:21, 7F

11/28 16:21, 8年前 , 8F
我想說那我把一個一個csv用 json 去轉再存入 dict後再次
11/28 16:21, 8F

11/28 16:21, 8年前 , 9F
用json去把dict轉換再上傳,之後如果需要用時就再把它下
11/28 16:21, 9F

11/28 16:21, 8年前 , 10F
載下來轉回原本的型態
11/28 16:21, 10F

11/28 16:53, 8年前 , 11F
我印象中,欄位是按照a-z去自動排的,可以再下指令讓
11/28 16:53, 11F

11/28 16:53, 8年前 , 12F
欄位順序變成你要的
11/28 16:53, 12F

11/28 17:25, 8年前 , 13F
我有個想法是 直接將csv的每個row直接轉成字串 可以嗎
11/28 17:25, 13F

11/28 17:25, 8年前 , 14F
? 這樣就可以保留順序
11/28 17:25, 14F

11/28 17:28, 8年前 , 15F
csv有column name的好處是可以直接用csv裡面的DictRead
11/28 17:28, 15F

11/28 17:28, 8年前 , 16F
er讀檔 就可以直接用類似row["name"]的方式讀那個row的
11/28 17:28, 16F

11/28 17:28, 8年前 , 17F
column值
11/28 17:28, 17F

11/28 21:05, 8年前 , 18F
json存成dict的話,dict本身就不保證順序,因此會亂
11/28 21:05, 18F

11/29 08:47, 8年前 , 19F
樓上沒錯 經hash過不保證保留順序
11/29 08:47, 19F

11/29 09:02, 8年前 , 20F
但我現在僅是dataframe轉json再轉回dataframe順序還是被
11/29 09:02, 20F

11/29 09:02, 8年前 , 21F
打亂說(還沒用dict)
11/29 09:02, 21F

11/29 09:22, 8年前 , 22F
json只是個格式而以 進到pandas還是會被轉成dict再存到
11/29 09:22, 22F

11/29 09:23, 8年前 , 23F
DataFrame
11/29 09:23, 23F

11/29 09:23, 8年前 , 24F
json只是個text的格式而已
11/29 09:23, 24F

11/29 09:26, 8年前 , 25F
但是dataframe會做排序 用字串排吧 忘了
11/29 09:26, 25F

11/29 09:27, 8年前 , 26F
11/29 09:27, 26F

11/29 11:55, 8年前 , 27F
感謝S大,此方法針對單一csv可行,但是如果是針對dict似
11/29 11:55, 27F

11/29 11:55, 8年前 , 28F
似乎就不行了,JSON data had unexpected key(s)
11/29 11:55, 28F

11/29 13:49, 8年前 , 29F
少轉一次json,感謝大家,感謝S大
11/29 13:49, 29F
文章代碼(AID): #1Q7HICfO (Python)