疑难解答“相关字段无效查找:icontains”

我在models.py中有以下模型:

class ListinoTraduttore(models.Model): traduttore = models.ForeignKey('Traduttore', related_name='Traduttore') linguaDa = models.ForeignKey(Lingua, related_name = "linguaDa") linguaA = models.ForeignKey(Lingua, related_name = "linguaA") prezzoParola = models.CharField(max_length=50, blank=True) prezzoRiga = models.CharField(max_length=50, blank=True) scontoCat = models.CharField(max_length=50, blank=True) scontoFuzzy = models.CharField(max_length=50, blank=True) scontoRipetizioni = models.CharField(max_length=50, blank=True) class Meta: verbose_name_plural = "Listini Traduttori" def __unicode__(self): return u"%s Da %s A %s Parola=%s Riga=%s ScontoCAT=%s ScontoFuzzy=%s ScontoRipetizioni=%s" % (self.traduttore, self.linguaDa, self.linguaA, self.prezzoParola, self.prezzoRiga, self.scontoCat, self.scontoFuzzy, self.scontoRipetizioni) class Traduttore(models.Model): nome = models.CharField(nomeString, max_length=50) cognome = models.CharField(cognomeString, max_length=50) nomeAzienda = models.CharField(nomeAziendaString, max_length=50, blank=True) codiceFiscale = models.CharField(codiceFiscaleString, max_length=50, blank=True) partitaIva = models.CharField(partitaIvaString, max_length=50, blank=True) indirizzo = models.CharField(indirizzoString, max_length=50, blank=True) telefono = models.CharField(telefonoString, max_length=50, blank=True) fax = models.CharField(faxString, max_length=50, blank=True) email = models.EmailField(max_length=50, blank=True) referente = models.CharField(referenteString, max_length=50, blank=True) valuta = models.ForeignKey(Valuta) metodoPagamento = models.ForeignKey(MetodoPagamento) datiBancari = models.CharField(datiBancariString, max_length=50, blank=True) programmiUtilizzati = models.ManyToManyField(Programma, blank=True) note = models.CharField(max_length=200, blank=True) listino = models.ManyToManyField(ListinoTraduttore, related_name='listino', blank=True) def __unicode__(self): return u"%s %s %s" % (self.nome, self.cognome, self.nomeAzienda) class Meta: verbose_name_plural = "Traduttori" 

而在admin.py中,我有以下几点:

 class TraduttoreAdmin(admin.ModelAdmin): list_display = ("nome", "cognome", "nomeAzienda") search_fields = ["nome", "cognome", "nomeAzienda"] class ListinoTraduttoreAdmin(admin.ModelAdmin): list_display = ("traduttore", "linguaDa", "linguaA", "prezzoParola", "prezzoRiga", "scontoCat", "scontoFuzzy", "scontoRipetizioni") search_fields = ['traduttore__nome", "linguaDa", "linguaA"] 

但是,当我尝试在ListinoTraduttore表中的pipe理页面进行search时,出现以下错误:

 TypeError at /admin/itrad/listinotraduttore/ Related Field has invalid lookup: icontains Request Method: GET Request URL: http://127.0.0.1:8000/admin/itrad/listinotraduttore/?q=Fenicio Django Version: 1.4.1 Exception Type: TypeError Exception Value: Related Field has invalid lookup: icontains Exception Location: /Library/Python/2.7/site-packages/django/db/models/fields/related.py in get_prep_lookup, line 142 Python Executable: /usr/bin/python Python Version: 2.7.2 Python Path: ['/Users/nicolac/Documents/DjangoProjects/mysite', '/Library/Python/2.7/site-packages/pip-1.1-py2.7.egg', '/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python27.zip', '/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7', '/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/plat-darwin', '/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/plat-mac', '/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/plat-mac/lib-scriptpackages', '/System/Library/Frameworks/Python.framework/Versions/2.7/Extras/lib/python', '/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/lib-tk', '/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/lib-old', '/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/lib-dynload', '/System/Library/Frameworks/Python.framework/Versions/2.7/Extras/lib/python/PyObjC', '/Library/Python/2.7/site-packages'] 

您是否曾尝试在ListinoTraduttoreAdmin search_fields的Lingua引用中添加ListinoTraduttoreAdmin ,如:

 class ListinoTraduttoreAdmin(admin.ModelAdmin): list_display = ("traduttore", "linguaDa", "linguaA", "prezzoParola", "prezzoRiga", "scontoCat", "scontoFuzzy", "scontoRipetizioni") search_fields = ['traduttore__nome", "linguaDa__field1", "linguaA_field2"] 

确保你没有直接添加任何ForeignKey或ManyToManyField到你的search_field。

改为使用Django的双下划线约定。 文档

 class ListinoTraduttoreAdmin(admin.ModelAdmin): list_display = ("traduttore", "linguaDa", "linguaA", "prezzoParola", "prezzoRiga", "scontoCat", "scontoFuzzy", "scontoRipetizioni") search_fields = ['traduttore__nome", "linguaDa__field1", "linguaA__field2"] 

这是(希望)简化答案。

不要过滤一个ForeignKey字段本身

改变这一点

 search_fields = ['foreinkeyfield'] 

(注意两个下划线)

 search_fields = ['foreinkeyfield__name'] 

name代表我们与ForeinKey关系的表中的字段名称。

希望这可以帮助

joinadmin.py

 admin.site.register(Traduttore, TraduttoreAdmin) admin.site.register(ListinoTraduttore, ListinoTraduttoreAdmin) 

请参阅链接https://docs.djangoproject.com/zh/dev/intro/tutorial02/