이 글은 Python 환경에서 Excel을 작동하는 방법을 공유합니다. 필요한 경우 친구가 참조할 수 있습니다.
1. 사용 가능한 타사 라이브러리
일반적으로 사용되는 라이브러리 xlrd(엑셀 읽기) 테이블, xlwt(엑셀 쓰기) 테이블, openpyxl(엑셀 테이블 읽기 및 쓰기) 등을 포함합니다. 대용량 데이터가 포함된 엑셀 테이블을 읽을 때는 xlrd가 openpyxl보다 더 효율적이어서 스크립트를 작성할 때 xlrd와 xlwt 두 라이브러리를 사용했습니다. 이러한 라이브러리 파일 중 어느 것도 기존 Excel 테이블의 내용을 수정하는 기능을 제공하지 않습니다. 일반적으로 원본 Excel의 내용은 읽고 처리한 다음 새 Excel 파일에 쓰는 것만 가능합니다.
pip search excel
를 사용하여 확인하실 수 있으며 더 많은 개발 패키지를 보실 수 있습니다.
2. 자주 묻는 질문
파이썬을 사용하여 엑셀 테이블을 처리할 때, 유니코드 인코딩과 엑셀에 기록되는 시간이라는 두 가지 더 어려운 문제를 발견했습니다.
파이썬의 기본 문자 인코딩은 유니코드이기 때문에 Excel에서 읽은 한자를 인쇄하거나 중국어 이름이 있는 Excel 표나 시트를 읽을 때 프로그램에서 UnicodeEncodeError: 'ascii' 코덱이 위치 0 -2의 문자를 인코딩할 수 없습니다: 서수라는 오류 메시지를 표시합니다. 범위(128) 내에 있지 않습니다. 이는 Windows에서 중국어는 gb2312 인코딩 방식을 사용하는데 Python은 이를 유니코드와 ASCII로 처리하여 디코딩하기 때문에 오류를 보고하기 때문입니다. 중국어 인쇄 문제를 해결하려면 VAR.encode('gb2312')를 사용하십시오. (때때로 결과가 출력되는 게 이상한데, 표시되는 것이 중국어가 아니고 코드 뭉치입니다.) 중국어 파일 이름으로 엑셀 표의 데이터를 읽으려면 앞에 'u'를 추가하면 됩니다. 나타내는 파일 이름 중국어 파일 이름은 유니코드로 인코딩됩니다.
엑셀에서는 시간과 날짜를 부동소수점 숫자로 표현합니다. '2013년 3월 20일'의 셀을 '일반' 형식으로 표현하면 내용은 '41353'이 되고, 셀 형식을 날짜로 변경하면 내용은 '2013년 3월 20일'이 되는 것을 알 수 있다. xlrd를 사용하여 Excel에서 날짜와 시간을 읽은 후 부동 소수점 숫자를 얻습니다. 따라서 Excel에 작성된 날짜와 시간이 부동 소수점 숫자인지 여부는 중요하지 않습니다. 일반적인 표현을 얻으려면 테이블의 표현을 날짜와 시간으로 변경하기만 하면 됩니다. Excel에서는 부동 소수점 숫자 1을 사용하여 1899년 12월 31일을 나타냅니다.
3. 자주 사용하는 함수
다음은 xlrd, xlwt, datetime의 날짜 관련 함수를 주로 소개합니다.
import xlrdimport xlwtfrom datetimedef testXlrd(filename): book=xlrd.open_workbook(filename) sh=book.sheet_by_index(0) print "Worksheet name(s): ",book.sheet_names()[0] print 'book.nsheets',book.nsheets print 'sh.name:',sh.name,'sh.nrows:',sh.nrows,'sh.ncols:',sh.ncols print 'A1:',sh.cell_value(rowx=0,colx=1) #如果A3的内容为中文 print 'A2:',sh.cell_value(0,2).encode('gb2312')def testXlwt(filename): book=xlwt.Workbook() sheet1=book.add_sheet('hello') book.add_sheet('word') sheet1.write(0,0,'hello') sheet1.write(0,1,'world') row1 = sheet1.row(1) row1.write(0,'A2') row1.write(1,'B2') sheet1.col(0).width = 10000 sheet2 = book.get_sheet(1) sheet2.row(0).write(0,'Sheet 2 A1') sheet2.row(0).write(1,'Sheet 2 B1') sheet2.flush_row_data() sheet2.write(1,0,'Sheet 2 A3') sheet2.col(0).width = 5000 sheet2.col(0).hidden = True book.save(filename)if __name__=='__main__': testXlrd(u'你好。xls') testXlwt('helloWord.xls') base=datetime.date(1899,12,31).toordinal() tmp=datetime.date(2013,07,16).toordinal() print datetime.date.fromordinal(tmp+base-1).weekday()
관련 권장 사항:
위 내용은 Python 환경에서 Excel을 작동하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!