it-swarm-pt.tech

Django: literal inválido para int () com base 10

Eu sou novo em Django e estou tentando passar o nome de um autor para uma visualização e filtrar objetos de citação com base no nome do autor. Aqui estão os códigos:

models.py

class Author(models.Model):
    author_name = models.CharField(max_length=50, default='unknown')
    author_info = models.TextField(max_length=1000)


class Quote(models.Model):
    author = models.ForeignKey(Author)
    quote = models.TextField(max_length=500)
    category= models.ForeignKey(Category)
    pub_date = models.DateTimeField('date published')

urls.py:

url(r'^quotes/(?P<name>\w+)/$', 'quotes.views.quotesbyauthor'),

views.py

def quotesbyauthor(request, name):
    aquotelist = Quote.objects.filter(author__exact = name)
    return render_to_response(quotes_by_author.html, {'aquotelist': aquotelist })

No entanto, recebo esse erro ao tentar obter http://127.0.0.1:8000/quotes/you/ ('você' é um objeto de autor de teste, já criado)

ValueError at /quotes/you/

invalid literal for int() with base 10: 'you'

Request Method:     GET
Request URL:    http://127.0.0.1:8000/quotes/you/
Django Version:     1.3.1
Exception Type:     ValueError
Exception Value:    

invalid literal for int() with base 10: 'you'

Exception Location:     /home/qliq/djenv/lib/python2.6/site-packages/Django/db/models/fields/__init__.py in get_prep_value, line 479
Python Executable:  /home/qliq/djenv/bin/python
Python Version:     2.6.6
Python Path:    

['/home/qliq/djenv/quoteapp',
 '/home/qliq/djenv/lib/python2.6/site-packages/distribute-0.6.10-py2.6.Egg',
 '/home/qliq/djenv/lib/python2.6/site-packages/pip-0.7.2-py2.6.Egg',
 '/home/qliq/djenv/lib/python2.6',
 '/home/qliq/djenv/lib/python2.6/plat-linux2',
 '/home/qliq/djenv/lib/python2.6/lib-tk',
 '/home/qliq/djenv/lib/python2.6/lib-old',
 '/home/qliq/djenv/lib/python2.6/lib-dynload',
 '/usr/lib/python2.6',
 '/usr/lib/python2.6/plat-linux2',
 '/usr/lib/python2.6/lib-tk',
 '/home/qliq/djenv/lib/python2.6/site-packages']

Agradeço sua ajuda para resolver isso.

27
qliq

Você deseja pesquisar no campo author_name Do autor, não no ID.

Quote.objects.filter(author__author_name=name)

Com sua pesquisa atual, author__exact, Django espera que name seja o ID do autor, isso gera um erro porque you não é um inteiro.

34
Alasdair
aquotelist = Quote.objects.filter(author__author_name__exact = name)

Tente alterar a linha correspondente para a acima. Do jeito que você o tem agora, você está combinando author com o nome fornecido, mas author provavelmente é considerado por seu ID aqui, definitivamente não por seu author_name. O formato é o seguinte:

Quote.objects.filter([model]__[field]__exact = [whatever])
4
U-DON

Eu acho que você deve redefinir sua migração, você pode ver este link:

https://stackoverflow.com/a/54768217/9533909

espero que ajude você.

0
hassanzadeh.sd