python pandas dataframe을 엑셀 vlookup처럼 활용하고 싶은데 쉽지 않습니다. 도와주세요
1014
작성한 질문수 1
하고 싶은 것
일부 주문이 서비스 유형: 픽업임에도 배달메뉴코드로 생성되어 이를 찾고 싶습니다.
(배달메뉴와 픽업메뉴 코드는 서로 다름)엑셀 vookup을 사용해서 상품코드를 배달 메뉴 테이블에서 검색하고, 검색되지 않으면 오주문으로 판단하는 코드를 구현했습니다.
같은 프로그램을 파이썬을 통해 구현해보고 싶은데, 다른 dataframe에 없는 값을 찾아 행을 추가하는 과정이 어려워 조언을 구하고 싶습니다.
파이썬 코드
df_pickup = 픽업 주문내역 데이터 프레임
delivery_menu_code = df_delivery_menu["상품코드"]
df_misorder = pd.DataFrame()
# 픽업 주문내역에서 상품코드를 꺼내 해당 상품코드가 배달 메뉴 코드에 포함되어 있는지 확인
# 만약에 코드가 없으면 해당 row를 df_misorder에 추가
for idx, row in df_pickup.iterrows():
misorder = df_delivery_menu[delivery_menu_code.str.contains(row["상품코드"], na = False)]
if len(misorder) != 0:
df_misorder.concat(row)
else:
pass
# 어떻게 추가해도 계속 0개로 나와서, 도와주시면 감사드리겠습니다!
len(df_misorder)
답변 1
1
안녕하세요, 인프런 AI 인턴이에요.
문제를 해결해 드리겠습니다. 코드를 보니 concat 함수를 사용하는 부분에 문제가 있습니다. concat 함수를 사용하여 데이터프레임에 행을 추가하려면, concat 함수의 첫 번째 인자로 추가할 데이터프레임을 전달해야 합니다. 그리고 ignore_index=True 옵션을 설정하여 새로운 인덱스를 할당해야 합니다. 아래 코드를 참고하여 수정해보세요.
df_misorder = pd.DataFrame()
for idx, row in df_pickup.iterrows():
misorder = df_delivery_menu[delivery_menu_code.str.contains(row["상품코드"], na=False)]
if len(misorder) != 0:
df_misorder = pd.concat([df_misorder, row.to_frame().T], ignore_index=True)
len(df_misorder)
이렇게 수정하면 df_misorder에 원하는 결과가 잘 추가될 것입니다. 추가로, df_delivery_menu의 “상품코드” 열에 중복된 값이 없다는 가정하에 코드가 작성되었습니다. 만약 중복된 값이 있다면, concat 함수로 인해 중복이 발생할 수 있습니다. 이 경우, drop_duplicates 함수를 사용하여 중복된 행을 삭제할 수 있습니다.
더 도움이 필요하시면 언제든지 물어보세요. 즐거운 프로그래밍 하세요!
multi_tool_agent.py 에서 arxiv tool 에러
0
7
1
로지스틱회귀, 회귀
0
28
2
가상 환경과 차이 도커 질문
0
16
1
자료 다운로드 위치 확인 부탁드립니다.
0
8
1
회귀 문제를 풀때 질문입니다.
0
32
1
불균형 처리 후 성능이 더 낮아졌다면,
0
46
2
실기 체험 제2유형 에러 문의
0
35
1
LIGHTGBM 으로 하면 pred값이 소수점 6자리까지 나오는게 맞나요
0
35
2
안녕하세요
0
14
2
3번문제 등분산 가정
0
35
2
작업형3 target 형 변환 질문
0
30
2
[작업형1] 연습문제 섹션1 ~ 10 의 section4
0
23
3
원핫인코딩과 레이블 인코딩에서 concat
0
44
2
agent 평가 관련 문의 드립니다.
0
15
1
제2유형 질문입니다.
0
39
2
WSL에서 Airflow 실행 시 로컬 venv 라이브러리 사용 여부 및 관리 방법
0
15
2
C()
0
36
2
작업형 2에서 strafity 적용 유무
0
44
2
수강 기간 연장 가능 여부 문의드립니다.
0
46
1
ols
0
36
2
2유형 작성관련 질문(일반 심화)
0
31
2
2유형 작성관련 질문
0
30
2
2유형 object컬럼 개수 다르면
0
37
2
코딩팡질문이요ㅠㅠ
0
37
2





