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

Фильтрование датафрейма по маске

28.09.2023, 10:04. Показов 979. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день, Спецы! Я новичок. У меня есть датафрейм, 88750 строк, 12 столбцов. Один из столбцов - 'Наименование _ТМЦ'.
Кусочек моего кода:
filtered_data = df_data.loc[df_data['Наименование_ТМЦ']=='Швеллер 16П ГОСТ 8240-97 Ст3сп ГОСТ 535-2005']

Эта строчка кода выводит в filtered_data все строки, в которых Наименование товара строго совпадает с указанным швеллером.
Но я знаю что в датафрейме есть швеллеры 16П, но другого ГОСТа , марки стали и пр. Помогите, пожалуйста, написать сортировку по маске - я должен указать 'Швеллер 16П', а на выходе получить все строки в которых есть Швеллер 16П с разными техническими параметрами. Спасибо
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
28.09.2023, 10:04
Ответы с готовыми решениями:

Замена значений в столбце датафрейма из другого датафрейма
Здравствуйте! Есть фрейм данных в столбце которого нужно навести порядок, привести значения к единому виду. Нужно это сделать следующим...

Фильтрование продуктов
Имеется таблица products_filters, в ней такая структура - id, product_id (ссылка на продукт из таблицы products), filter_value_id (ссылка...

Фильтрование по времени
Создал базу с помощь TClientDataSet, есть поле Дата, есть два DateEdit, нужно фильтровать от первой даты до другой. ds1.Filter:='...

5
Эксперт Python
8850 / 4501 / 1864
Регистрация: 27.03.2020
Сообщений: 7,316
28.09.2023, 12:19
Dzhamshed,Например, так:
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
import pandas as pd
import numpy as np
 
adr = ['Швеллер 16П ГОСТ 8240-97 Ст3сп ГОСТ 535-2005', 
       'Швеллер 17П ГОСТ 8240-97 Ст3сп ГОСТ 535-2005', 
       'Швеллер 18П ГОСТ 8240-97 Ст3сп ГОСТ 535-2005', 
       'Швеллер 19П ГОСТ 8240-97 Ст3сп ГОСТ 535-2005', 
       'Швеллер 16П ГОСТ 8240-97 Ст3сп ГОСТ 535-2005']
df = pd.DataFrame({'Наименование_ТМЦ': adr, 'other': list('12345')})
print(df)
 
####################################
patt = "Швеллер 16П"
df_res = df[df['Наименование_ТМЦ'].str.contains(patt)]
####################################
 
print(df_res)
0
0 / 0 / 0
Регистрация: 23.04.2022
Сообщений: 4
28.09.2023, 13:07  [ТС]
Спасибо большое, Gdez!
Поигрался с твои кодом, вроде хорошо и интересно. Но когда прогнал пример на своем фрейме,
то получил вот такую ошибку - ValueError: Cannot mask with non-boolean array containing NA / NaN values.

Это что, где-то в данных есть пустая строчка? Я правильно понял? Если так, то как ее проигнорировать?
0
Эксперт Python
8850 / 4501 / 1864
Регистрация: 27.03.2020
Сообщений: 7,316
28.09.2023, 13:20
Dzhamshed,
Python
1
2
3
…
df_res = df[df['Наименование_ТМЦ'].str.contains(patt, na=False)]
https://pandas.pydata.org/docs... tains.html
Если будут еще проблемы, то желательно сам файл с данными
0
0 / 0 / 0
Регистрация: 23.04.2022
Сообщений: 4
28.09.2023, 13:30  [ТС]
Спасибо, Gdez! Все работает. Можно нескромный вопрос - почему за все время изучения Python я нигде не встречал таким методов, которые используешь здесь ты? Я пытался использовать slip(), но у меня ничего путного не получалось. Не сможешь рекомендовать мне хорошую литературу?? Спасибо.
0
Эксперт Python
8850 / 4501 / 1864
Регистрация: 27.03.2020
Сообщений: 7,316
28.09.2023, 16:29
Dzhamshed, ссылку на оф документацию к pandas приложил в прошлом сообщении
Кратко можно почитать во вложениях
Вложения
Тип файла: pdf ama2015_pandas.pdf (955.9 Кб, 3 просмотров)
Тип файла: pdf Abdrakhmanov_M_I_-_Pandas_Rabota_s_dannymi_-_2020.pdf (1.07 Мб, 0 просмотров)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
28.09.2023, 16:29
Помогаю со студенческими работами здесь

Фильтрование сигнала
Прекрасные формучане, помогите разрешить проблему) Есть сигнал, хочу вырезать только спектр со значениями, отличными от нуля. Хотел бы...

Фильтрование и SQL запросы
Здравствуйте! Подскажите как реализовать следующее: Допустим есть таблица "Книги", она состоит из: индекса...

Замена фразы по маске на другую фразу по маске в файле
Добрый день! Имеется задача, которую, к сожалению, пока не могу реализовать: Есть текстовый файл состоящий из множества строк. В нем...

фильтрование с использованием регулярных выражений
Добрый день недавно начал осваивать регулярные выражения и уже освоил что такое метасимволы и символьные классы и чем они отличаются от...

Фильтрование списка с сохранением id итема
Пишу программу в которой есть listview, в котором n строчек - итемов. каждый итем имеет свой id. Когда я фильтрую листвью то итем, который...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru