私はExcelファイルにインデックスを作成しようとしていて、whooshパッケージを使用しましたが、リストのインデックスが範囲外であるというエラーが見つかりました。お願いします、誰か助けてくれませんか?私のコードは次のとおりです。
from whoosh import fields, index
import os.path
import csv
import codecs
# This list associates a name with each position in a row
columns = ["juza","chapter","verse","analysis"]
schema = fields.Schema(juza=fields.NUMERIC,
                       chapter=fields.NUMERIC,
                       verse=fields.NUMERIC,
                       analysis=fields.KEYWORD)
# Create the Whoosh index
indexname = "index"
if not os.path.exists(indexname):
  os.mkdir(indexname)
ix = index.create_in(indexname, schema)
# Open a writer for the index
with ix.writer() as writer:
  # Open the CSV file
  with codecs.open("yom.csv", "rb","utf8") as csvfile:
    # Create a csv reader object for the file
    csvreader = csv.reader(csvfile)
    # Read each row in the file
    for row in csvreader:
      # Create a dictionary to hold the document values for this row
      doc = {}
      # Read the values for the row enumerated like
      # (0, "juza"), (1, "chapter"), etc.
      for colnum, value in enumerate(row):
        # Get the field name from the "columns" list
        fieldname = columns[colnum]
        # Strip any whitespace and convert to unicode
        # NOTE: you need to pass the right encoding here!
        value = unicode(value.strip(), "utf-8")
        # Put the value in the dictionary
        doc[fieldname] = value
      # Pass the dictionary to the add_document method
      writer.add_document(**doc)
    writer.commit()
`
このエラーが発生し、理由がわかりませんか? エラー:
Traceback (most recent call last):
  File "C:\Python27\yarab.py", line 39, in <module>
    fieldname = columns[colnum]
IndexError: list index out of range
そして私のcsvファイル:
1   3   1   Al+ POS:ADJ LEM:r~aHoma`n ROOT:rHm MS GEN
1   3   2   Al+ POS:ADJ LEM:r~aHiym ROOT:rHm MS GEN
1   4   1   POS:N ACT PCPL LEM:ma`lik ROOT:mlk M GEN
1   4   2   POS:N LEM:yawom ROOT:ywm M GEN
1   4   3   Al+ POS:N LEM:diyn ROOT:dyn M GEN
1   5   1   POS:PRON LEM:<iy~aA 2MS