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

Как удалить в файле json лишние числа, которых нет в текстовом файле

25.02.2023, 17:30. Показов 1204. Ответов 10

Студворк — интернет-сервис помощи студентам
Добрый день, поскажите как можно реализовать.Есть два файла, один файл в формате json (вес 0,5мб), внутри которого такая информация:

[

{

"player": 8888,
"club": 600

},

{

"player": 4444,
"club": 502
},

{

"player": 1111,
"club": 606
},

{

"player": 3333,
"club": 740
},

{

"player": 2222,
"club": 520
}
и так далее

другой файл текстовый (весит 3 мб) и он с таким содержимым:

1111

2222

3333

8888
и так далее

Нужно удалить из файла json те числа, которых нет в текстовом файле. Поиск нало делать именно по "player", но при удалении "club" тоже надо удалять вместе с player.

В данном примере удаляются вторые player и club ("player": 4444 и "club": 502)
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
25.02.2023, 17:30
Ответы с готовыми решениями:

Не работает модуль json (функции json.dump(), json.load()
При запуске кода по сохранению и прочтению данных, сгенерированных пользователем: import json ...

json удалить лишнее в выводе
Приветствую всех есть скрипт jsonData =...

Как распарсить данные из первого json-а и перекинуть их в другой json
Добрый день, столкнулся с такой задачей. Есть вот такой json Необходимо извлечь...

10
132 / 96 / 40
Регистрация: 24.03.2022
Сообщений: 357
25.02.2023, 17:35
Задание нормально оформите и сделаю.
1
0 / 0 / 0
Регистрация: 12.01.2022
Сообщений: 6
25.02.2023, 17:43  [ТС]
piton21, Извините, а как оформить? Что не так с моим оформлением?
0
132 / 96 / 40
Регистрация: 24.03.2022
Сообщений: 357
25.02.2023, 18:27
Кнопочка python при вставке кода, можно и небольшие образцы файлов приложить. Чтобы самому задание не набирать.

Добавлено через 33 минуты
Цитата Сообщение от Royal7 Посмотреть сообщение
В данном примере удаляются вторые player и club ("player": 4444 и "club": 502)
А
Code
1
2
"player": 8888,
"club": 600
и
Code
1
2
"player": 2222,
"club": 520
почему не удаляются?
0
0 / 0 / 0
Регистрация: 12.01.2022
Сообщений: 6
25.02.2023, 20:22  [ТС]
"player": 8888,
"club": 600
И
"player": 2222,
"club": 520

Они не удаляются, потому что числа 8888 и 2222 есть есть в текстовом файле. Удаляются только те числа, которых нет в текстовом файле. Поиск надо проводить по числам "players", (потому что в текстовом файле только эти числа), затем если в файле json находится число players которого нет в текстовом файле, тогда эта графа (players и clubs) удаляются из json.
0
132 / 96 / 40
Регистрация: 24.03.2022
Сообщений: 357
25.02.2023, 20:36
Цитата Сообщение от Royal7 Посмотреть сообщение
которых нет в текстовом файле
Да, точно.
0
26.02.2023, 11:43

Не по теме:

Смотрю оформление так и не осилил

0
 Аватар для rim41
1045 / 313 / 78
Регистрация: 16.03.2020
Сообщений: 954
26.02.2023, 11:54
piton21,

Не по теме:

Тяжело начинающим программистам даётся вникание в интуитивно понятный интерфейс форума... Ой тяжело...

0
132 / 96 / 40
Регистрация: 24.03.2022
Сообщений: 357
26.02.2023, 12:27
Эхх, доброта меня погубит, ей Богу..
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
js = [{"player": 8888,
       "club": 600},
      {
          "player": 4444,
          "club": 502},
      {
          "player": 1111,
          "club": 606},
      {
          "player": 3333,
          "club": 740
      },
      {
          "player": 2222,
          "club": 520},
      {
          "player": 9999,
          "club": 520},
      {
          "player": 7777,
          "club": 520}
      ]
with open('file.txt', 'r') as f:
    s = list(map(int, f.read().split('\n')))
js_correct = [i for i in js if i['player'] in s]
1
0 / 0 / 0
Регистрация: 12.01.2022
Сообщений: 6
26.02.2023, 17:31  [ТС]
Цитата Сообщение от piton21 Посмотреть сообщение
Эхх, доброта меня погубит, ей Богу..
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
js = [{"player": 8888,
       "club": 600},
      {
          "player": 4444,
          "club": 502},
      {
          "player": 1111,
          "club": 606},
      {
          "player": 3333,
          "club": 740
      },
      {
          "player": 2222,
          "club": 520},
      {
          "player": 9999,
          "club": 520},
      {
          "player": 7777,
          "club": 520}
      ]
with open('file.txt', 'r') as f:
    s = list(map(int, f.read().split('\n')))
js_correct = [i for i in js if i['player'] in s]
Здравствуйте, пост уже нельзя изменить, поэтому не смог отредактировать оформление, но в следующий раз учту.
Спасибо вам за ответ.
Я приложил файлы, можете пожалуйста на них проверить, а то у меня что то не выходит.
И так же хотел бы попросить, можно ли вывести разницу в отдельный файл? То есть то, что удаляется из json, вывести в отдельный текстовый файл, чтобы проверить , не лишнее ли удаляется.
Вложения
Тип файла: zip players.zip (311.8 Кб, 3 просмотров)
0
132 / 96 / 40
Регистрация: 24.03.2022
Сообщений: 357
26.02.2023, 18:03
Цитата Сообщение от Royal7 Посмотреть сообщение
не выходит
А что не выходит?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
26.02.2023, 18:03
Помогаю со студенческими работами здесь

Нужно написать программу, считывающую одинаковые, которые стоят рядом символы в строке и удалить лишний символ
Необходимо в строке, полученной со стандартного ввода, найти повторяющиеся символы (одинаковые...

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

Обход JSON любой вложенности, json to list
Нужно написать скрипт который сможет обойти json любой вложенности и все его ключи и значения...

Парсить yaml в json используя библиотеку re, но НЕ используя библиотеки yaml и json
У меня есть yaml файл: --- name: "Среда" lessons: - name: "ПРАКТИКУМ ПО...

Как удалить лишний спарсенный элемент?
Всем привет ! Я парсю дату с этого ресурса.Все бы хорошо,но есть одно но.Когда я получил эти данные...


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

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Новые блоги и статьи
Установка Qt Creator для C и C++: ставим среду, CMake и MinGW без фреймворка Qt
8Observer8 05.04.2026
Среду разработки Qt Creator можно установить без фреймворка Qt. Есть отдельный репозиторий для этой среды: https:/ / github. com/ qt-creator/ qt-creator, где можно скачать установщик, на вкладке Releases:. . .
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
Отображение реквизитов в документе по условию и контроль их заполнения
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеСпецтехники", разработанного в конфигурации КА2. Данный документ берёт данные из другого нетипового документа. . .
Фото всей Земли с борта корабля Orion миссии Artemis II
kumehtar 04.04.2026
Это первое подобное фото сделанное человеком за 50 лет. Снимок называют новым вариантом легендарной фотографии «The Blue Marble» 1972 года, сделанной с борта корабля «Аполлон-17». Новое фото. . .
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать программный контроль на предмет проведения документа. . .
Программный контроль заполнения реквизитов табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: 1. Реализовать контроль заполнения реквизита. . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: при создании документов установить период списания автоматически. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru