Excel File에서 파이썬으로 읽어온 데이터를 변경 후 원래 엑셀을 변경하는 방법을 알고 싶습니다.

해결됨
habilis1016 프로필

이번 강의 도전 과제가 주민번호 뒷자리를 * 로 바꿔서 가려보기

였는데 하기와 같이 변경하면 쥬피터 노트북으로 출력은 가능 합니다. 

import openpyxl

work_book = openpyxl.load_workbook('data_kr.xlsx')

work_sheet = work_book.active

for each_row in work_sheet.rows:

    print(re.sub('-[0-9]{7}', '-*******', each_row[1].value))

work_book.close()

저는 이왕 바꾼 데이터니깐 그걸 다시 원래 Excel에서 넣어서 수정을 하고 싶은데 잘 안되네요 

import openpyxl

work_book = openpyxl.load_workbook('data_kr.xlsx')

work_sheet = work_book.active

for each_row in work_sheet.rows:

    newdata =[re.sub('-[0-9]{7}', '-*******', each_row[1].value)]

    work_sheet.append(newdata)

    

work_book.save('new.xlsx')

work_book.close()

이렇게 하면 

이렇게까지만 되는데 원래 자리에 넣고 싶거든요...

그리고 append를 하면 적어도 A열에 덮어 질줄 알았는데  왜 완전히 다른 행에 써지는지도 모르겠습니다.

잔재미코딩 프로필
잔재미코딩 1달 전

이미 work_sheet 에 기존 파일의 데이터가 있다보니, 그 이후에 써져서 그런것같아요.

새로 엑셀 파일을 만드는 코드를 쓰셔서, Workbook()으로 새로 생성하신 엑셀쉬트에 데이터를 넣으시면 좋을 것 같습니다.

감사합니다.

잔재미코딩 프로필
잔재미코딩 1달 전

아니시면, 다음 코드를 참고하셔서, 새로 엑셀 파일을 만들어서, 변경한 데이터만 넣어주시면 어떨까해요 감사합니다.

import openpyxl

def write_excel_template(filename, sheetname, listdata):

    excel_file = openpyxl.Workbook()

    excel_sheet = excel_file.active

    if sheetname != '':

        excel_sheet.title = sheetname

    

    for item in listdata:

        excel_sheet.append(item)

    excel_file.save(filename)

    excel_file.close()

habilis1016 프로필
habilis1016 1달 전

강사님 질문 답변 감사합니다.

취미로 배우기 시작했는데 재밌어서 다른 것들도 다 수강하기 시작했습니다.

문과에 비전공자라 처음에는 어이가 없었는데, 하나씩 따라하다 보니 재밌네요

앞으로도 더 많은 강의 부탁 드립니다.

지식공유자 되기
많은 사람들에게 배움의 기회를 주고,
경제적 보상을 받아보세요.
지식공유참여
기업 교육을 위한 인프런
“인프런 비즈니스” 를 통해 모든 팀원이 인프런의 강의들을
자유롭게 학습하는 환경을 제공하세요.
인프런 비즈니스