i have string in format:
{apple:"34253453",oranges:"sweet",x:"cool"},{apple:"34222453",oranges:"dry",x:"warm"},{apple:"31113453",oranges:"bitter",x:"hot"},{apple:"38883453",oranges:"sweet",x:"cool"}
and looking create dataframe column labels 'apple','oranges','x' , values placed in respective rows.
i've tried use solution: python convert comma separated list pandas dataframe ast.literal_eval convert list before transforming dataframe no luck.
your string invalid json
, necessary replace first:
import ast s = '{apple:"34253453",oranges:"sweet",x:"cool"},{apple:"34222453",oranges:"dry",x:"warm"},{apple:"31113453",oranges:"bitter",x:"hot"},{apple:"38883453",oranges:"sweet",x:"cool"}' ss = '[' + s.replace('{', '{"').replace(':"','":"').replace('",', '","') + ']' print (ss) [{"apple":"34253453","oranges":"sweet","x":"cool"}, {"apple":"34222453","oranges":"dry","x":"warm"}, {"apple":"31113453","oranges":"bitter","x":"hot"}, {"apple":"38883453","oranges":"sweet","x":"cool"}]
df = pd.dataframe(ast.literal_eval(ss)) print (df) apple oranges x 0 34253453 sweet cool 1 34222453 dry warm 2 31113453 bitter hot 3 38883453 sweet cool
df = pd.dataframe(pd.io.json.loads(ss)) print (df) apple oranges x 0 34253453 sweet cool 1 34222453 dry warm 2 31113453 bitter hot 3 38883453 sweet cool
Comments
Post a Comment