2016-11-08 23 views
1

我有一个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。

+0

在urls.py中,您应该正确包含正则表达式,例如,如果您想通过id获取基因: 'url(r'^ genes /(?P \ d +)',views.variant_info,name = 'variant_info'),' 这种方式将基因ID传递给视图,那么您应该以这种方式检索变体对象:'variant_info = Variant.objects.filter(gene__id = gene)' – abidibo

+0

我没有基因ID我的桌子。主要关键是基因名称 – trouselife

+0

哦,我明白了。这是非常罕见的,无论哪种方式,定义字符匹配在reg exp中:'url(r'^ genes /(?P [^ /] +)',views.variant_info,name ='variant_info')'然后'variant_info = Variant.objects.filter(gene__gene = gene)' – abidibo

回答

0

为你需要的东西的URL喜欢在年底

r'^genes/(?P<gene>TP\d+)$' 

只匹配数字(我想,否则会尝试匹配的字符串,并只接受第一场比赛)

为对于你的第二个问题:对不起,但我不明白你问的问题。 但看你的代码,我想,你希望由外国型号的性能进行过滤:

variant_info = Variant.objects.filter(gene__gene__contains=gene) 

这意味着在目标基因的基因领域进行搜索。

ps。这开始看起来很奇怪,我建议改变模型,以类似

class Gene(models.Model): 
    name = models.CharField(primary_key=True, max_length=110) 
    ... 
+0

我想要的是当我点击TP53时这个字符串“TP53”)通过我的urls正则表达式r'^ genes /(?P )'作为,这样就可以继承我的view.py函数“variant_info”,这样在test_app/genes/TP53页面上它就会查询我的数据库中的Variant表使用参数gene =“TP53”,我可以将查询结果呈现给这个页面。 – trouselife

2

的问题是,你的(?P<gene>)没有任何字符匹配,所以你将永远有你的观点gene=''

试着改变你的网址模式:

url(r'^genes/(?P<gene>\w+)/$', views.variant_info, name='variant_info'), 

这将接受字母A-Z,A-Z,数字0-9和下划线的gene说法。为了与您的其他观点以及美元保持一致,我添加了斜线,因为通常这是一个好主意。

相关问题