• 목록
  • 아래로
  • 위로

안녕하세요?


아미나의 '티스탁' 님께서 정리하신 명언 엑셀파일을 


PHP 등에서 사용하기 위해 CSV 파일로 변환하는 스크립트입니다.


http://amina.co.kr/bbs/board.php?bo_table=skin_member&wr_id=4169


무료로 제공되고 있고, 열어보면 아시겠지만 굉장히 많은 명언이 잘 정리되어 있어요 ^^



XLS 파일로 저장되어 있는데 openpyxl 라이브러리로 읽으려면 우선 엑셀에서 xlsx 파일로 변환해야 합니다.


스크립트를 실행하면 원하는 구간의 B열에 담긴 명언만 추출해서 CSV 파일로 변환해줍니다.


delimiter로는 엔터를 사용했는데 작업에 따라서는 ';'가 더 편할 수도 있겠네요.


PHP에서는 fgetcsv() 함수로 불러오면 됩니다.



import openpyxl, csv

wb = openpyxl.load_workbook('파일명.xlsx')
ws = wb.active

start_row = 시작 열
end_row = 마지막 열

mylist = []
count = 1
for column in ws['B']:
     if count >= start_row and count <= end_row:
         mylist.append(column.value)
     count += 1

with open("파일명.csv", "w") as f:
    wr = csv.writer(f, delimiter='\n')
    wr.writerow(mylist)



openpyxl 라이브러리도 업데이트가 여러 번 진행되면서 꽤 많은 부분이 변했네요.


공식문서를 확인해보니 대체로 이전보다 간결하게 사용할 수 있는 방법으로 바뀐 것 같네요.


그래서 현재의 라이브러리는 "파이썬 프로그래밍으로 지루한 작업 자동화하기" 책에 실린 것과 차이가 조금 있더군요.


이 스크립트는 openpyxl 최신 버전을 기준으로 작성해서 구 버전에서는 돌아가지 않을 것 같네요.



그럼 편안한 저녁 되시고 무더위에 항상 건강하세요!


굿밤 되세요 ^^



+) 인코딩의 변환이 필요한 경우 아래 스크립트를 활용하시면 됩니다.


before = codecs.open('변환전파일명', 'r', encoding='euc_kr')
after = codecs.open('변환후파일명', 'w', encoding='utf-8')
for line in before:
     line = line.replace(u'\xa0', ' ') 
     out.write(line)
before.close()
after.close()


작성자
이니스프리 119 Lv. (0%) 1925050/115200000EXP

Make StudyForUs Great Again!

 

CSVpuymXAAAVVpd.jpg

댓글 0

권한이 없습니다.
번호 제목 글쓴이 날짜 조회 수
공지 [작업 완료] 설 명절 맞이 서버 업데이트 안내 3 마스터 마스터 24.02.11.17:21 806
공지 [중요] 호스팅 만료와 관련하여 일부 수칙이 변경됩니다. 4 마스터 마스터 23.01.14.02:23 4478
487 [Python] 문자열에서 숫자만 뽑아서 정수로 반환하는 함수 이니스프리 이니스프리 20.02.12.00:01 141
486 [Python] 딕셔너리 자료형에서 .get() 메서드 사용시 에러 회피하기 이니스프리 이니스프리 20.02.15.22:48 141
485 [Requests] params, data 전달시에 딕셔너리의 구조가 복잡한 경우 해결방법 이니스프리 이니스프리 19.11.17.14:55 146
484 [Python] Youtube Playlist에 담긴 동영상들을 역순으로 불러오기 이니스프리 이니스프리 21.03.19.00:41 146
483 [Python] 유클리드 호제법 2 image 이니스프리 이니스프리 20.02.15.17:21 148
482 카고야 VPS FAQ 번역 이니스프리 이니스프리 20.03.19.20:04 148
481 [Python] 최적화된 윈도우용 Tensorflow가 있는 Github repository 이니스프리 이니스프리 20.05.20.18:47 150
480 [Python] dictionary 2개의 평균을 구하여 내림차순 정렬하기 이니스프리 이니스프리 24.04.21.17:29 150
479 링크 파싱 모듈을 제작하다가 깨달은 점 ㅠㅠ 이니스프리 이니스프리 19.08.27.22:06 151
478 JavaScript에서 Array로 Multipul Evaluation을 사용하면서 어디에 오류가 발생했는지 확인하기 Seia Seia 18.10.21.14:47 152
477 [파이썬] 길어진 로그 파일을 100줄로 줄이는 스크립트 이니스프리 이니스프리 19.12.25.11:49 152
476 [학술정보] Breaking character and natural image based CAPTCHA using feature classification 1 이니스프리 이니스프리 18.11.13.16:01 153
475 [Python] 수를 뒤집는 두 가지 방법 3 이니스프리 이니스프리 20.02.11.22:24 153
474 TCP BBR을 사용하여 기존 TCP 구현보다도 훨씬 빠른 속도를 즐기는 방법 2 image Seia Seia 20.01.19.07:01 154
473 [펌] 하나의 키 입력으로 유튜브 광고 차단하기 - Block YouTube Ads With a Single Keystroke 2 이니스프리 이니스프리 20.06.14.10:19 157
472 [Python] 구버전 KeyCaptcha 정답 좌표 찾기 image 네모 네모 21.07.09.02:46 157
471 [PHP] 파일을 읽어서 각 행을 리스트로 만들기 이니스프리 이니스프리 19.07.10.20:29 160
470 [팁] 모바일 앱 빌더 해피보이 20.04.02.08:59 160
469 마지막 방문일자 알려주기 슬기 슬기 18.10.11.00:31 162
468 AMD KOREA 라이젠 3500X 공식 런칭 예정 image 이니스프리 이니스프리 19.10.15.17:50 162