猿问

将 json 文件保存到一个 csv 中

我有 100 个类似的 json 文件,我想将这些 json 文件的内容保存到一个 csv 文件中。这是我为此编写的代码。但这并没有做我想做的事。所需的输出是 csv 文件: https: //drive.google.com/file/d/1cgwdbnvETLf6nO1tNnH0F_-fLxUOdT7L/view ?usp=sharing

请告诉我怎样才能得到上面的输出?谢谢 JSON 文件格式:https://drive.google.com/file/d/1-OZYrfUtDJmwcRUjpBgn59zJt5MjtmWt/view ?usp=sharing

list_=['politifact13565', 'politifact13601'] 

for i in list_:

    with open("{}/news content.json".format(i)) as json_input:

        json_data = json.load(json_input, strict=False)

        mydict = {}

        mydict["url"] = json_data["url"]

        mydict["text"] = json_data["text"]

        mydict["images"]=json_data["images"]

        mydict["title"]=json_data["title"]

        df = pd.DataFrame.from_dict(mydict, orient='index')

        df = df.T

        df.append(df, ignore_index=True)

        df.to_csv('out.csv')

        print(df)

解决了:


list_=['politifact13565', 'politifact13601'] 

for i in list_:

    with open("{}/news content.json".format(i)) as json_input:

        json_data = json.load(json_input, strict=False)

        mydict = {}

        mydict["url"] = json_data["url"]

        mydict["text"] = json_data["text"]

        mydict["images"]=json_data["images"]

        mydict["title"]=json_data["title"]

        df = pd.DataFrame.from_dict(mydict, orient='index')

        df = df.T

        df.append(df, ignore_index=True)

        df.to_csv('out.csv', mode='a', header=False)

        print(df)


慕桂英546537
浏览 125回答 2
2回答

Helenr

list_=['politifact13565', 'politifact13601'] for i in list_:    with open("{}/news content.json".format(i)) as json_input:        json_data = json.load(json_input, strict=False)        mydict = {}        mydict["url"] = json_data["url"]        mydict["text"] = json_data["text"]        mydict["images"]=json_data["images"]        mydict["title"]=json_data["title"]        df = pd.DataFrame.from_dict(mydict, orient='index')        df = df.T        df.append(df, ignore_index=True)        df.to_csv('out.csv', mode='a', header=False)        print(df)

MYYA

您的解决方案非常接近所需的输出,您只需转置导入的 json:import globdirectory = "your/path/to/jsons/*.json"df = pd.concat([pd.read_json(f, orient="index").T for f in glob.glob(directory)], ignore_index=True)之后您可以使用保存 dfdf.to_csv("tweets.csv")希望这对您有帮助!
随时随地看视频慕课网APP

相关分类

Python
我要回答