2017-05-15 51 views
-1

Excelの列にリストを書き込もうとしてエラーが発生しました。私はOpenpyxlエラー - 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

は、プロセスはこのエラーはするループで発生しているように見える終了コード1

を終え

列VにワークシートaSheetにmatchingNameの各値を書き込もうとしています。私は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()を使用する必要があります。

関連する問題