Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/9: Рейтинг темы: голосов - 9, средняя оценка - 4.67
0 / 0 / 0
Регистрация: 10.02.2020
Сообщений: 117

Не получается сравнить 2 JSON

07.07.2021, 15:47. Показов 1932. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
JSON имеют разную структуру, но в обеих поля с ФИО, по нему и сравниваю. Мне надо в 1 JSON убрать все записи где значение ФИО повторяется во 2-м SON Но алгоритм не до конца правильно работает. Какие-то записи правильно добавляет какие-то просто пропускает.

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
        excel_students_list = ExcelReader.read_excel(self.excel_path)
        perco_students_list, request_status = PERCo_API.get_students_list()
 
        if request_status == 200:
            list_for_add = []
 
            flag = False
 
            for excel_item in excel_students_list:
                for perco_item in perco_students_list:
                    if excel_item["ФИО"] in perco_item["name"]:
                        flag = True
                        break
                if not flag:
                    print(excel_item)
                    list_for_add.append(excel_item)
                    flag = False
 
            print(list_for_add)
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
07.07.2021, 15:47
Ответы с готовыми решениями:

Как сравнить цены из 2 json файлов
Здравствуйте, как сделать чтобы проводилась проверка из первого json файла со вторым по названию, если не был найден не один товар с таким...

Как проанализировать 2 файла json и сравнить их, используя Python?
Есть приложение, на странице которого выводятся иконки других приложений. Они выводятся двумя способами. Надо сравнить эти способы. Для...

Не получается изменить json
есть json со следующей структурой userData = { "last_name": "", "first_name": "", ...

4
Автоматизируй это!
Эксперт Python
 Аватар для Welemir1
7390 / 4817 / 1246
Регистрация: 30.03.2015
Сообщений: 13,667
Записей в блоге: 29
07.07.2021, 15:48
poihgvc, приведи маленький пример, вот 2 жсона, на выходе надо получить вот это.
0
0 / 0 / 0
Регистрация: 10.02.2020
Сообщений: 117
07.07.2021, 15:59  [ТС]
Welemir1, 1-ый JSON:
JSON
1
2
3
4
5
6
7
8
9
10
11
12
{
'ФИО': Иванов Иван Иванович
...
},
{
'ФИО': Петров Петр Петрович
...
},
{
'ФИО': Иванов Петр Иванович
...
}
2-ой JSON
JSON
1
2
3
4
5
6
7
8
{
'name': Иванов Иван Иванович
...
},
{
'name': Васильев Василий Васильевич
...
}
Результат

JSON
1
2
3
4
5
6
7
8
{
'ФИО': Петров Петр Петрович
...
},
{
'ФИО': Иванов Петр Иванович
...
}
Вообще мне надо в 1-ом JSON оставить только те записи где ФИО не повторяется во 2-ом JSON. Я решил сделать 3 массив куда буду добавлять эти самые записи.

Добавлено через 1 минуту
причем алгоритм который я написал работает в обратном случае: если надо найти те записи которые повторяются.
0
1303 / 843 / 409
Регистрация: 12.03.2018
Сообщений: 2,305
07.07.2021, 16:06
Лучший ответ Сообщение было отмечено Welemir1 как решение

Решение

poihgvc, если память позволяет, сохраните все name из 2-го json'а в список ignore = [item['name'] for item in perco_students_list]. Затем пройдитесь по 1-ому и проверяйте if excel_item['ФИО'] not in ignore. Если условие выполняется, добавляйте в результат.
1
Автоматизируй это!
Эксперт Python
 Аватар для Welemir1
7390 / 4817 / 1246
Регистрация: 30.03.2015
Сообщений: 13,667
Записей в блоге: 29
07.07.2021, 16:32
poihgvc, алгоритм предыдущего оратора что надо, только не лист формируй а множество!
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
07.07.2021, 16:32
Помогаю со студенческими работами здесь

Flask и SQLAlchemy и JSON. Не получается преобразовать результат запроса в json
У меня есть БД построенная из этих моделей с помощью миграций: # Class Class stores info about dish categories class...

Не получается правильно сравнить два числа
from tkinter import * from random import * def rand_num(event): n = randint(1, 100) s = ent.get() if s == n: ...

Сравнить json и вывести результат
Здравствуйте! Только учу, столкнулся с проблемой, нужно сравнить два файла типа json. Открываю два заранее подготовленных файла...

Данные вида Json сравнить с числом
Здравствуйте! Делаю интернет-магазин, и храню товар в MySQL. Есть поле category_id по которому товары выводятся, если пользователь выбрал...

Сравнить два JSON (проверить структуру)
Приветствую, уважаемые посетители форума! Я столкнулся с некой проблемой. Мне необходимо сравнить два json по их структуре, не учитывая...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru