python pandas dataframe을 엑셀 vlookup처럼 활용하고 싶은데 쉽지 않습니다. 도와주세요
1008
작성한 질문수 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 함수를 사용하여 중복된 행을 삭제할 수 있습니다.
더 도움이 필요하시면 언제든지 물어보세요. 즐거운 프로그래밍 하세요!
강의 내용 실습관
0
7
0
노션 파일 없음
0
12
3
한국투자 증권
0
17
2
52번 강의 질문입니다.
0
12
2
https://youtu.be/ziTLbsE9Cbc 유튜브 노션 링크 권한 부탁드립니다.
0
13
2
Breadth (등락 비율) 분석
0
17
1
교육자료가 너무 오래되어서 지시한대로 진행하려 해도 안됩니다.
0
12
1
작업형1 - 연습문제 16~39 풀이는 몇강을 보면 되나요?
0
23
1
26 .강의 프롬프트와 프롬프트파일(part3) 내용이 차이가 있어요.
0
23
2
작업형 1 -연습문제 4-6
0
21
1
구글 그래피티 마켓 오류...?!
0
29
2
디스코드 소통창구는 없어졌나요 ??
0
36
2
FOREIGN KEY 정리하기, 영상대로 SQL코드 복붙해도 안되요.
0
19
1
모델 서빙과 관련된 강좌 출시 예정된 바가 있으신지 여쭤봅니다!
0
24
2
모델 서빙과 관련된 강좌가 출시되는지 질문드립니다.
0
19
2
20번강좌에 대한 질문입니다.
0
27
2
6-6
0
29
1
작업형 1 유형 부분
0
31
2
수강평 이벤트
0
26
2
작업형 1 (삭제예정, 구 버전)
0
46
2
강의노트는 어디있나요?
0
22
1
노션 학습 자료 권한 요청
0
28
2
수강기간 연장 문의드립니다.
0
31
1
2유형 레이블 인코딩 VS 원핫 인코딩
0
35
3





