Pythonライブラリのjsonはjson文字列をdictに変換できる一方で、若干癖がある。
以下だとjson.loadsでdictに変換される。
sample= json.loads('{"sample1":"a","sample2":"b"}')
data:image/s3,"s3://crabby-images/e2eb6/e2eb693f0e55b05dd5cfe0fc28b2183ad29e3fc8" alt=""
しかし、シングルクォートとダブルクォートを入れ替えると変換できない。
sample2= json.loads("{'sample1':'a','sample2':'b'}")
JSONDecodeError: Expecting property name enclosed in double quotes: line 1 column 2 (char 1)
data:image/s3,"s3://crabby-images/35b61/35b61ca17d38d9667d93a425e64730c110349329" alt=""
解決方法
シンプルにreplaceで置換するとよい。
sample3= json.loads("{'sample1':'a','sample2':'b'}".replace("\'",'\"'))
data:image/s3,"s3://crabby-images/0eb32/0eb3285dcc69f9979d1adc6c3478b537a6597baf" alt=""
DataFrameの場合applyで展開する。
import pandas as pd
#make data
sample_data={"sample":["a","b","c"]}
sample_df=pd.DataFrame(sample_data)
sample_df["sample_str"] = "{'sample1':'a','sample2':'b'}"
#str to dict
sample_df["sample_dict"] = sample_df["sample_str"].apply(lambda x: json.loads(x.replace("\'", '\"')))
data:image/s3,"s3://crabby-images/e86bf/e86bfa37f41077773e69eed6170780cddeaf030e" alt=""
コメント