Dataframe из JSON в формате текста?

Можно ли создать фрейм данных из JSON, отформатированного как текст, а не как объект Python?

С помощью объекта Python я мог бы, например, сделать:

from pandas.io.json import json_normalize
import requests

response = requests.get(url, params).json()
df = json_normalize(response)

но я хочу добиться того же с response = requests.get(url,params).text (хотя выравнивание не требуется).

Можете ли вы поместить несколько строк данных?

Karn Kumar 09.11.2018 18:21

@pygo почему понимание списка?

roganjosh 09.11.2018 18:24

@pygo Я не буду читать JSON из файла, я хочу поместить ответ requests.get(url,params).text в фрейм данных.

barciewicz 09.11.2018 18:26

@barciewicz, да, понял, вот и я сказал, что неправильно прочитал вопрос, извините :-)

Karn Kumar 09.11.2018 18:28

Гарантированно ли .text является действительной строкой JSON?

r.ook 09.11.2018 19:37
Почему в Python есть оператор "pass"?
Почему в Python есть оператор "pass"?
Оператор pass в Python - это простая концепция, которую могут быстро освоить даже новички без опыта программирования.
Некоторые методы, о которых вы не знали, что они существуют в Python
Некоторые методы, о которых вы не знали, что они существуют в Python
Python - самый известный и самый простой в изучении язык в наши дни. Имея широкий спектр применения в области машинного обучения, Data Science,...
Основы Python Часть I
Основы Python Часть I
Вы когда-нибудь задумывались, почему в программах на Python вы видите приведенный ниже код?
LeetCode - 1579. Удаление максимального числа ребер для сохранения полной проходимости графа
LeetCode - 1579. Удаление максимального числа ребер для сохранения полной проходимости графа
Алиса и Боб имеют неориентированный граф из n узлов и трех типов ребер:
Оптимизация кода с помощью тернарного оператора Python
Оптимизация кода с помощью тернарного оператора Python
И последнее, что мы хотели бы показать вам, прежде чем двигаться дальше, это
Советы по эффективной веб-разработке с помощью Python
Советы по эффективной веб-разработке с помощью Python
Как веб-разработчик, Python может стать мощным инструментом для создания эффективных и масштабируемых веб-приложений.
0
5
145
2

Ответы 2

Обычно я создаю фрейм данных из json, используя read_json.

import pandas as pd
import requests

data = requests.get(url, params).content
df = pd.read_json(data)
df.head()

Спасибо, к сожалению, это дает мне ValueError: arrays must all be same length в строке read_json, я думаю, потому что мой JSON вложен. Вы знаете, как это обойти?

barciewicz 09.11.2018 19:01

заменить строку read_json на: from pandas.io.json import json_normalize, загружает df = json_normalize (загружает (данные))

lfkopp 10.11.2018 02:09

Если ваш response = requests.get(url,params).text гарантированно предоставит вам действительную строку JSON, все, что вам нужно сделать, это следующее:

from pandas.io.json import json_normalize, loads
import requests

response = requests.get(url, params).text
df = json_normalize(loads(response))

Здесь мы используем jsonloads для преобразования строки JSON в объект Python перед передачей обратно в json_normalize.

Другие вопросы по теме