Странная ошибка с iloc в Pandas: IndexError: одиночный позиционный индексатор выходит за пределы

Я работаю над проектом с Pandas и Flask, и я получаю эту странную ошибку, которая заключается в следующем: IndexError: одиночный позиционный индексатор выходит за пределы. Однако сама ошибка не в том, что странно, а в том, как она возникает. У меня есть фляжное приложение, одна из страниц которого является формой, которая выполняет вызов ajax. Пользователь вводит название книги, и возвращается средний рейтинг этой книги. Если я наберу «Это», рейтинг вернется. Все работает нормально. Однако, если я наберу «Девушка в поезде», я получу следующую ошибку:

Traceback (most recent call last):
  File "/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/site-packages/flask/app.py", line 1994, in __call__
    return self.wsgi_app(environ, start_response)
  File "/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/site-packages/flask/app.py", line 1985, in wsgi_app
    response = self.handle_exception(e)
  File "/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/site-packages/flask/app.py", line 1540, in handle_exception
    reraise(exc_type, exc_value, tb)
  File "/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/site-packages/flask/_compat.py", line 33, in reraise
    raise value
  File "/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/site-packages/flask/app.py", line 1982, in wsgi_app
    response = self.full_dispatch_request()
  File "/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/site-packages/flask/app.py", line 1614, in full_dispatch_request
    rv = self.handle_user_exception(e)
  File "/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/site-packages/flask/app.py", line 1517, in handle_user_exception
    reraise(exc_type, exc_value, tb)
  File "/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/site-packages/flask/_compat.py", line 33, in reraise
    raise value
  File "/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/site-packages/flask/app.py", line 1612, in full_dispatch_request
    rv = self.dispatch_request()
  File "/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/site-packages/flask/app.py", line 1598, in dispatch_request
    return self.view_functions[rule.endpoint](**req.view_args)
  File "/Users/mikecuddy/Desktop/Coding/Python/book_ratings/app.py", line 75, in book_look_up
    rating = book.book_rating(title)
  File "/Users/mikecuddy/Desktop/Coding/Python/book_ratings/books.py", line 17, in book_rating
    rating = info.iloc[0][12]
  File "/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/site-packages/pandas/core/indexing.py", line 1296, in __getitem__
    return self._getitem_axis(key, axis=0)
  File "/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/site-packages/pandas/core/indexing.py", line 1612, in _getitem_axis
    self._is_valid_integer(key, axis)
  File "/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/site-packages/pandas/core/indexing.py", line 1526, in _is_valid_integer
    raise IndexError("single positional indexer is out-of-bounds")
IndexError: single positional indexer is out-of-bounds

Однако, если я введу тот же заголовок в свой код панд, я получу рейтинг! Я знаю, что мой код Pandas работает нормально. Я также скажу, что любая книга, в названии которой есть одно слово, например «Оно», прекрасно работает. Моя ошибка возникает только с несколькими словами в заголовке. Я проследил проблему до этого, но не могу продвинуться дальше. Теперь мой код:

HTML-код

<form class='title_lookUp_div' id='book_look_up_form'>
    <label>Book Title: </label><input id='title' name='title' type='text'>
    <p>Result: <span id='result'>?</span></p>
    <button>Submit</button>
</form>

JS/AJAX вызов:

$(document).ready(function(){
  $('#book_look_up_form').bind('submit', function(event){
    event.preventDefault();
      $.ajax({
        data: {
          title: $('#title').val()
        },
       type: 'POST',
       url: '/book_look_up',
       success: function(data){
       $('#result').text(data.result).show();
      }
    });
   });
  });

Код панды:

    def book_rating(self, title):
       #Gettting the row of data for the title that the user entered.
       info = self.__data[self.__data.original_title == title]
       rating = info.iloc[0][12]
       return rating

код app.py:

@app.route('/book_look_up',methods=['POST'])
def book_look_up():
   #Recieving the data from the ajax call
   title = request.form['title']
   #The data in the CSV file has the first letter of each word capitalized 
   title = title.title()
   #Creating the object that will deal with the data from CSV file.
   book = Books()
   rating = book.book_rating(title)
   if title: 
      return jsonify(result = rating)
   return jsonify({'error' : 'Missing Data'})

Как я уже сказал, код Pandas работает нормально, вызов app.py и ajax работает нормально. Только когда в данных есть несколько слов, все падает, и я получаю вышеуказанное сообщение об ошибке. Любая помощь будет здорово! Благодарю вас!


person ravenUSMC    schedule 29.09.2017    source источник
comment
Каково значение info в коде pandas при сбое?   -  person Keith    schedule 29.09.2017
comment
Извините за задержку, значение информации: Пустой фрейм данных. Тем не менее, я почти уверен, что ошибка моя - то, что введено, должно точно соответствовать тому, что находится в файле CSV. Итак, у меня был метод .title(), превращающий девушку в поезде в девушку в поезде, когда он должен был быть первым! Придется придумать лучший способ получить матч!   -  person ravenUSMC    schedule 30.09.2017
comment
Таким образом, я понял, что моя ошибка связана с тем, что пользовательский ввод соответствует тому, что находится в файле csv.   -  person ravenUSMC    schedule 30.09.2017


Ответы (1)


После долгих обзоров выясняется, что это проблема регулярных выражений. Пожалуйста, смотрите мои комментарии выше. В этом примере мои проблемы были вызваны методом .title(), который менял способ поиска заголовка в CSV-файле.

person ravenUSMC    schedule 29.09.2017