• 목록
  • 아래로
  • 위로




안녕하세요?


스포어 회원님들께서도 다들 업무에서 MS 엑셀을 많이 활용하실 것 같은데요.


엑셀을 자동화하면 업무가 크게 수월해지는 경우가 많겠죠 ^^


그래서 20번대 강좌에서는 파이썬에서 엑셀 파일을 직접 읽고 쓸 수 있는 모듈인 OpenPyXL에 대해 다뤄보고자 합니다.


OpenPyXL 이외에도 파이썬에서 엑셀을 조작하는 여러 모듈이 있지만, 이 모듈은 (1) xlsx 형식을 지원하며 (2) 읽기와 쓰기가 동시에 가능하고 (3) 퍼포먼스도 그럭저럭 괜찮은 편이라는 점에서 가장 무난하다고 생각됩니다.


엑셀 매크로를 사용해보지 않으신 분들은 다소 생소하실 수도 있지만, 나름대로 직관적인 접근방법을 갖고 있다고 생각합니다.


그럼 문서 - 시트 - 셀 순서대로 접근하는 방법을 살펴보겠습니다.




1. 엑셀 문서 열기


import openpyxl
wb = openpyxl.load_workbook('filename.xlsx')


openpyxl.load_workbook() 함수는 파일 이름을 전달받고, workbook 유형의 데이터값을 반환합니다.




2. 통합문서에서 시트 열기


import openpyxl
wb = openpyxl.load_workbook('filename.xlsx')
sheet = wb.get_sheet_by_name('sheet1')


workbook 객체에서 get_sheet_by_name() 메서드를 호출하면 시트를 얻을 수 있습니다.

(이 메서드는 depreciated될 예정이며 앞으로는 wb['sheet1'] 형태로 사용하면 됩니다.)


한편 get_active_sheet() 메서드를 호출하면 활성시트를 바로 얻을 수 있습니다.

(이 메서드는 depreciated될 예정이며 앞으로는 .active 메서드를 사용하면 됩니다.)




3. 시트에서 셀의 값을 얻기


import openpyxl
wb = openpyxl.load_workbook('filename.xlsx')
sheet = wb.get_sheet_by_name('sheet1')
value = sheet['A1'].value


cell 객체는 .value 속성을 가지며, 이 속성은 해당 셀에 저장된 값을 지닙니다.


.value 속성은 문자열, 날짜시간, 정수 등 타입을 그대로 반환하다는 점에서 매우 강력합니다 ㄷㄷ


한편 행열이 길어지면 알파벳을 사용하기 어렵기 때문에, sheet.cell(row=28, column=32)과 같은 방식으로 알파벳 대신 정수를 사용할 수 있습니다.


여기에서 row와 column의 값은 0이 아니라 1에서부터 시작한다는 점을 주의하세요!


아울러 sheet.get_highest_row(), sheet.get_highest_column()을 활용하여 행열의 크기를 알면, 이를 for 문과 range() 함수에 활용할 수 있습니다!

(현재 최신버전에서는 sheet.max_row, sheet.max_column으로 대체되었습니다.)




4. 시트에서 행열을 얻기


import openpyxl
wb = openpyxl.load_workbook('filename.xlsx')
sheet = wb.get_sheet_by_name('sheet1')
data = list(sheet['A1':'E5'])


특정 영역의 셀 객체들을 얻기 위하여 엑셀 매크로와 유사한 방식의 표현도 가능합니다.


아울러 sheet.columns[5], sheet.rows[10] 이런 방법으로 엑셀의 특정 행 또는 열 전체를 클릭한 것과 마찬가지의 결과를 얻을 수 있습니다!




지금까지 문서 - 시트 - 셀의 순서대로 접근을 하여 데이터를 얻는 방법에 대해 살펴보았습니다.


다음 강좌에서는 문서를 저장하고 셀의 값을 쓰는 방법에 대해 살펴보겠습니다.


작성자
이니스프리 100 Lv. (92%) 814930/816080EXP

당분간 개인적인 사정으로 자유게시판에는 글이나 댓글을 작성하지 못합니다.

다른 게시판에는 중립적인 글과 정보글만 작성할 예정입니다.

 

CSVpuymXAAAVVpd.jpg

댓글 3

ilovepc
자바의 POI 같은건가요? ㅎㅎ
comment menu
2020.02.04. 16:24

신고

"ilovepc님의 댓글"

이 댓글을 신고 하시겠습니까?

이니스프리 작성자 → ilovepc
profile image

안녕하세요??

제가 자바를 잘 다루지 못해서 정확히는 모르겠지만 Apache POI와 유사한 라이브러리 같네요~!

아마 Apache POI가 보다 강력한 기능을 제공할 것 같네요 ^^

comment menu
2020.02.04. 18:54

신고

"이니스프리님의 댓글"

이 댓글을 신고 하시겠습니까?

이니스프리 작성자
profile image
참고로 엑셀파일의 작성자 및 최종변경자를 확인하는 방법은 아래 글에 적었어요 :)
https://studyforus.com/tipnknowhow/716909
comment menu
2020.08.11. 13:22

신고

"이니스프리님의 댓글"

이 댓글을 신고 하시겠습니까?

권한이 없습니다.
번호 제목 글쓴이 날짜 조회 수
24 [번외편 - 한컴한글] 스마트한 문서 작성을 위한 팁 (작성 중) 이니스프리 이니스프리 20.08.08.13:50 134
23 [Requests-HTML] Requests와 비교할 때의 장점! (네이버 뉴스 등 크롤링) 7 image 이니스프리 이니스프리 20.05.14.19:08 522
22 22. [OpenPyXL] 엑셀 문서 저장하기 / 시트 추가하기 / 셀에 입력하기 14 image 이니스프리 이니스프리 20.02.02.00:46 1347
21. [OpenPyXL] 엑셀 문서를 열고 시트에서 셀의 값을 얻기 3 image 이니스프리 이니스프리 20.02.01.23:46 652
20 [BeautifulSoup] 자식태그를 제거하기 - .decompose() & .extract() 10 image 이니스프리 이니스프리 20.01.16.00:07 1766
19 [python-telegram-bot] 4096자 글자수 제한을 우회하는 방법 image 이니스프리 이니스프리 20.01.12.11:25 602
18 [Requests] Selenium을 이용한 Cloudflare의 우회 3 image 이니스프리 이니스프리 20.01.08.19:51 1058
17 9. [정리] 파이써닉한 파이썬 문법 팁 for COS Pro image 이니스프리 이니스프리 20.01.04.23:47 491
16 [번외편] 네이버 동영상에서 자막을 파일로 추출하는 방법 2 image 이니스프리 이니스프리 19.12.25.22:34 1306
15 4. 문자열 처리 (2) - 문자열 조작에 대한 기본함수 및 메서드 1 image 이니스프리 이니스프리 19.12.12.02:27 381
14 6. 리스트와 관련된 기본함수 및 메서드 7 image 이니스프리 이니스프리 19.12.10.21:16 513
13 3. 문자열 처리 (1) - 문자열 접근 및 검색방법 4 image 이니스프리 이니스프리 19.12.09.20:00 1001
12 [Selenium] Requests의 session을 Selenium으로 보내기 image 이니스프리 이니스프리 19.12.07.14:17 1287
11 1. 반복문 (1) - while 문 5 image 이니스프리 이니스프리 19.12.06.20:50 597
10 (序) Python 강좌를 시작하며... 2 image 이니스프리 이니스프리 19.12.05.21:55 351
9 [Pillow] 파이썬 Pillow 라이브러리를 이용하여 이미지의 배경을 transparent하게 만들기 11 image 이니스프리 이니스프리 19.08.04.13:40 1829
8 [번외편 - 법률] 나무위키의 서술 중 법률용어의 사용에 있어 바로잡아야 할 부분 image 이니스프리 이니스프리 19.07.17.22:44 346
7 [번외편 - 유튜브] Youtube API를 이용하거나 또는 이용하지 않고 채널ID를 추출하는 방법 1 image 이니스프리 이니스프리 19.07.16.17:55 830
6 [Selenium] Selenium에서 send_keys를 막아놓은 경우 해결책 이니스프리 이니스프리 19.07.04.05:52 905
5 [번외편 - 아미나] Basic Youtube Title Widget 1.0에서 처음에 엑박으로 뜨는 경우의 해결책 3 image 이니스프리 이니스프리 18.12.15.23:02 654