python - 如何将 JSON 列表转换为 CSV 文件中的两个不同列?

标签 python json csv dataframe parsing

这是我在这个精彩网站上的第一个问题,我需要知道如何将复杂信息从 JSON 导出到 CSV。 问题是我需要从列中的列表中获得两个不同的值。

我尝试了很多不同的组合,但都失败了,所以我向社区请求了我最后的资源之一。 我的代码是这样的:

def output(alerts):
        output = list()
        for alert in alerts:
            applications = alerts['applications']
            for app in applications:
                categories = app['categories']
                for cat in categories:
                    output_alert = [list(cat.items())[0], app['confidence'], app['icon'],
                                    app['name'], app['version'], app['website'], alerts['language'], alerts['status']]
                    output.append(output_alert)

        df = pd.DataFrame(output, columns=['Categories', 'Confidence', 'Icon', 'Name', 'Version', 'Website',
                                           'Language', 'Status'])
        df.to_csv(args.output)
        print('Scan completed, you already have your new CSV file')
        return

enter image description here

我给您留了一张 CSV 文件的图片,其中 B 列有问题(我在那里有一个列表),但实际上我需要两列,每个值......

我附上了来自 REST API 的 JSON 响应

{'applications': [{'categories': [{'59': 'JavaScript libraries'}],
               'confidence': '100',
               'icon': 'Lo-dash.png',
               'name': 'Lodash',
               'version': '4.17.15',
               'website': 'http://www.lodash.com'},
              {'categories': [{'12': 'JavaScript frameworks'}],
               'confidence': '100',
               'icon': 'RequireJS.png',
               'name': 'RequireJS',
               'version': '2.3.6',
               'website': 'http://requirejs.org'},
              {'categories': [{'13': 'Issue trackers'}],
               'confidence': '100',
               'icon': 'Sentry.svg',
               'name': 'Sentry',
               'version': '4.6.2',
               'website': 'https://sentry.io/'},
              {'categories': [{'1': 'CMS'},
                              {'6': 'Ecommerce'},
                              {'11': 'Blogs'}],
               'confidence': '100',
               'icon': 'Wix.png',
               'name': 'Wix',
               'version': None,
               'website': 'https://www.wix.com'},
              {'categories': [{'59': 'JavaScript libraries'}],
               'confidence': '100',
               'icon': 'Zepto.png',
               'name': 'Zepto',
               'version': None,
               'website': 'http://zeptojs.com'},
              {'categories': [{'19': 'Miscellaneous'}],
               'confidence': '100',
               'icon': 'webpack.svg',
               'name': 'webpack',
               'version': None,
               'website': 'https://webpack.js.org/'},
              {'categories': [{'12': 'JavaScript frameworks'}],
               'confidence': '0',
               'icon': 'React.png',
               'name': 'React',
               'version': None,
               'website': 'https://reactjs.org'}],  'language': 'es',  'status': 'success'}

[{'59': 'JavaScriptlibraries'}] 最后一件事是我的大问题!感谢您的时间和帮助!

最佳答案

您可以尝试在 output_alert 变量中使用 list(cat.keys())[0], list(cat.values())[0] 来提取键和值分开。

关于python - 如何将 JSON 列表转换为 CSV 文件中的两个不同列?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61156151/

相关文章:

python - 使用Python访问JSON对象中包含的列表

javascript - 在 Node.js 中将 2 个 json 对象合并为一个

python - 通过 For 循环使用另一个 JSON 数据的 .append() 生成的列表

Node.js:按定义的顺序返回 promise

Python - 将 PDF 返回给浏览器

python - 使用正则表达式从 unicode 字符串中提取数字

python - Cython 会加速 erf() 计算吗?

json - 基于 CSV 将 JSON 对添加到 JSON 文件

java - 使用java将日期和时间的csv文件加载到oracle数据库中

unit-testing - Spock:从 CSV 文件读取测试数据