python 은 openpyxl 을 사용 하여 병합 셀 의 값 을 읽 습 니 다.
test.xlsx 의"Sheet 1"작업 표 에서 A1:D3 구역 의 값 은 다음 과 같다 고 가정 합 니 다.
지정 한 줄,열,대응 하 는 작업 표를 매개 변수 로 지정 해 야 합 니 다.병합 셀 을 정확하게 분석 하여 지정 한 셀 의 값 을 가 져 올 수 있 습 니 다.
행렬 에 따라 해당 하 는 셀 의 값 을 직접 가 져 오 면 왼쪽 상단 이 아 닌 다른 셀 을 합 쳐 None 값 을 가 져 옵 니 다.다음 과 같 습 니 다.
if __name__ == "__main__":
wb = xl.load_workbook("test.xlsx")
sheet_ = wb["Sheet1"]
print(sheet_["A1"].value) # 1
print(sheet_["A2"].value) # None
print(sheet_["D1"].value) # 8
print(sheet_["D2"].value) # None
print(sheet_["D3"].value) # None
해결 방향:대응 하 는 셀 을 가 져 온 후 이 셀 이 병합 셀 인지 판단 합 니 다.그렇다면 이 병합 영역 을 찾 아 왼쪽 상단 의 값 을 되 돌려 줍 니 다.
sheet.merged 통과 하기cell_ranges 속성,현재 워 크 시트 의 모든 병합 영역 목록 을 가 져 올 수 있 습 니 다:
테스트 코드:
if __name__ == "__main__":
wb = xl.load_workbook("test.xlsx")
sheet_ = wb["Sheet1"]
merged_ranges = sheet_.merged_cell_ranges #
for merged_range in merged_ranges:
print(type(merged_range)) #
print(merged_range) #
결 과 는 다음 과 같다.우 리 는 openpyxl.worksheet.merge.Merged CellRange 를 돌 며 소스 코드 를 찾 았 는데 in 작업 이 정 의 된 것 을 발 견 했 습 니 다.in 을 통 해 특정한 좌표 가 지역 내 에 있 는 지 직접 확인 할 수 있 습 니 다.
이때 우 리 는 이미 합병 칸 을 얻 는 조건 을 기본적으로 갖 추 었 다.
전체 코드 는 다음 과 같 습 니 다:
import openpyxl as xl
from openpyxl.worksheet.worksheet import Worksheet
from openpyxl.cell import MergedCell
def parser_merged_cell(sheet: Worksheet, row, col):
"""
。
, ,
:param sheet:
:param row:
:param col:
:return:
"""
cell = sheet.cell(row=row, column=col)
if isinstance(cell, MergedCell): #
for merged_range in sheet.merged_cell_ranges: #
if cell.coordinate in merged_range:
#
cell = sheet.cell(row=merged_range.min_row, column=merged_range.min_col)
break
return cell
if __name__ == "__main__":
wb = xl.load_workbook("test.xlsx")
sheet_ = wb["Sheet1"]
for row_index in range(1, 4):
for col_index in range(1, 5):
cell_ = parser_merged_cell(sheet_, row_index, col_index)
print(" %s %s :%s" % (row_index, col_index, cell_.value))
결 과 는 다음 과 같다.제1 행 제1 열:1
제1 행 제2 열:2
제1 행 제3 열:3
1 행 4 열:8
제2 행 제1 열:1
제2 행 제2 열:4
제2 행 제3 열:5
두 번 째 줄 4 열:8
세 번 째 줄 1 열:6
3 행 2 열:7
3 행 3 열:7
3 행 4 열:8
python 이 openpyxl 을 사용 하여 병합 셀 의 값 을 읽 는 것 에 관 한 이 글 은 여기까지 소개 되 었 습 니 다.더 많은 관련 python openpyxl 은 병합 셀 의 내용 을 읽 습 니 다.이전 글 을 검색 하거나 아래 의 관련 글 을 계속 찾 아 보 세 요.앞으로 많은 지원 을 바 랍 니 다!
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
로마 숫자를 정수로 또는 그 반대로 변환그 중 하나는 로마 숫자를 정수로 변환하는 함수를 만드는 것이었고 두 번째는 그 반대를 수행하는 함수를 만드는 것이었습니다. 문자만 포함합니다'I', 'V', 'X', 'L', 'C', 'D', 'M' ; 문자열이 ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.