2017-05-15 5 views
-1

Excel 열에 목록을 쓰려고하는데 오류가 발생했습니다. 내가 열 V. 워크 시트 aSheet에 종료 코드 1Openpyxl 오류 - Valueerror {0}이 (가) 올바른 좌표 또는 범위가 아닙니다.

이 오류가 보인다 완료

Traceback (most recent call last): File "C:/Users/PycharmProjects/smartCompare/excelmain.py", line 40, in aSheet[V] = matchingName[i3] File "C:\Users\AppData\Local\Programs\Python\Python36\lib\site-packages\openpyxl\worksheet\worksheet.py", line 380, in setitem self[key].value = value File "C:\Users\AppData\Local\Programs\Python\Python36\lib\site-packages\openpyxl\worksheet\worksheet.py", line 357, in getitem min_col, min_row, max_col, max_row = range_boundaries(key) File "C:\Users\AppData\Local\Programs\Python\Python36\lib\site-packages\openpyxl\utils\cell.py", line 129, in range_boundaries raise ValueError("{0} is not a valid coordinate or range") ValueError: {0} is not a valid coordinate or range

프로세스를 matchingName의 각 값을 쓰기를 시도하고하는 for 루프에서 발생합니다. 내가 openpyxl 문서를 확인했지만 해결에 행운을 빕니다. 어떤 충고? 당신은 잘못된 좌표이 ws["'W4'"] 같은 조회를 만드는

import openpyxl 
from difflib import SequenceMatcher 

fruit = [] 
fruit2 = [] 
compareScore = [] 
matchingName = [] 
matchingRatioNum = [] 
wb = openpyxl.load_workbook('test.xlsx') 
aSheet = wb.get_sheet_by_name('AMIS') 
cSheet = wb.get_sheet_by_name('CMMS') 

for col in aSheet['F']: 
    fruit.append(col.value) 

for col in cSheet['E']: 
    fruit2.append(col.value) 

length = 5 
length2 = 5 
i = 0 
i2 = 0 

for i in range(0, length): 
    for i2 in range(0, length2): 
     ratio = SequenceMatcher(None, fruit[i], fruit2[i2]).ratio() 
     compareScore.append(ratio) 
     i2 += 1 
    matchRatio = compareScore.index(max(compareScore)) 
    match = fruit2[matchRatio] 
    ratioNum = compareScore[matchRatio] 
    matchingName.append(match) 
    matchingRatioNum.append(ratioNum) 
    compareScore = [] 
    i += 1 

i3 = 0 
for i3 in range(0, length): 
    V = "'" + 'V' + str(i3+1) + "'" 
    aSheet[V] = matchingName[i3] 
    del V 
    i3 += 1 

i4 = 0 
for i4 in range(0, length): 
    W = "'" + 'W' + str(i4+1) + "'" 
    aSheet[W] = matchingRatioNum[i4] 
    del W 
    i4 += 1 
wb.save('test.xlsx') 
+0

전체 추적이 필요합니다. –

+0

@CharlieClark가 전체 추적을 추가했습니다. – PanczerTank

답변

1

, 당신은 ws["W4"]을 원한다. 항상을 프로그래밍 방식으로 액세스하려면 ws.cell()을 사용해야합니다.