我有一个django应用程序'test_app'。 test_app页面 - “domain/test_app /”有一个到应用程序“基因”中另一个页面的链接。这需要我“domain/test_app/genes /”。在这个页面中,我有一个链接列表,它来自我的django数据库中一个名为“gene”的表格,它位于test_app/models.py中,类别为Gene。这通过属性'gene'链接到另一个名为“Variants”的表作为外键。Django的应用程序视图 - 如何从URL中的django数据库中获取条目并从数据库获取更多信息以查看该视图?
这是所有在test_app/models.py:
class Gene(models.Model):
gene = models.CharField(primary_key=True, max_length=110)
transcript = models.CharField(max_length=100)
def __str__(self):
return self.gene
class Variant(models.Model):
variant = models.CharField(primary_key=True, max_length=210)
gene = models.ForeignKey(Gene, on_delete=models.CASCADE)
cds = models.CharField(max_length=150)
def __str__(self):
return self.variant
我test_app/urls.py urlpatterns的是这样的:
urlpatterns = [
url(r'^$', views.test_app, name='test_app'),
url(r'^genes/$', views.genes, name='genes'),
url(r'^genes/(?P<gene>)', views.variant_info, name='variant_info'),
]
和test_app/views.py这个样子(链接到我的模板中的test_app/templates/test_app /目录中):
def test_app(request):
template = loader.get_template('test_app/index.html')
return render(request, 'test_app/index.html')
def genes(request):
gene_list = Gene.objects.all()
context = {'gene_list': gene_list}
return render(request, 'test_app/genes.html', context)
def variant_info(request, gene):
variant_info = Variant.objects.filter(gene=gene)
return(request, 'test_app/gene_info.html', {'variant_info': variant_info}
我在我的基因表中有一个基因列表数据库。当使用'gene_list = Gene.objects.all()'获得这些基因时,这可以正常工作。然后,我将这个列表呈现为模板,作为我的“domain/test_app/genes”页面上的一系列链接。例如,当我在此页面上点击TP53时,它会转到“domain/test_app/genes/TP53 /”。这带我到正确的页面。
但是,我显然没有这个urlpattern正确的正则表达式,因为当我输入更多的数字或字符,如/ TP53098120918它仍然会进入同一页面。即使当我把r'^基因/(?P)$'这仍然发生,我不明白为什么?
但我所面临的主要问题是从我的数据库中的变体表中获取信息,并将其渲染到特定的基因页面,如domain/test_app/genes/TP53。
当我点击TP53它不经过我的看法功能“variant_info”为基因的说法,因为该行:
variant_info = Variant.objects.filter(gene=gene)
不从数据库获取任何信息 - 我认为这将通过基因=“TP53”当我点击链接,因此这将是:
variant_info = Variant.objects.filter(gene='TP53')
这将与基因TP53返回从变量表中的信息。我不知道如何从views.py中的基因功能正确访问TP53。
在urls.py中,您应该正确包含正则表达式,例如,如果您想通过id获取基因: 'url(r'^ genes /(?P \ d +)',views.variant_info,name = 'variant_info'),' 这种方式将基因ID传递给视图,那么您应该以这种方式检索变体对象:'variant_info = Variant.objects.filter(gene__id = gene)' –
abidibo
我没有基因ID我的桌子。主要关键是基因名称 – trouselife
哦,我明白了。这是非常罕见的,无论哪种方式,定义字符匹配在reg exp中:'url(r'^ genes /(?P [^ /] +)',views.variant_info,name ='variant_info')'然后'variant_info = Variant.objects.filter(gene__gene = gene)' –
abidibo