Django 应用程序视图 - 如何从 url 中的 django 数据库中获取条目并从数据库中获取更多视图信息?
Posted
技术标签:
【中文标题】Django 应用程序视图 - 如何从 url 中的 django 数据库中获取条目并从数据库中获取更多视图信息?【英文标题】:Django app view - how to get an entry from the django database in the url and to obtain more information from the database for the view? 【发布时间】:2017-03-22 08:28:38 【问题描述】:我有一个 django 应用程序“test_app”。 test_app 页面 - “domain/test_app/”有一个链接到应用程序“Genes”中的另一个页面。这将我带到“域/test_app/genes/”。在此页面中,我有一个链接列表,这些链接来自我的 django 数据库中名为“gene”的表,该表在 test_app/models.py 中作为 Gene 类。这通过属性“gene”作为外键链接到另一个名为“Variants”的表。
这些都在 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'^genes/(?P)$' 这仍然发生,我不明白为什么?
但我遇到的主要问题是从我的数据库中的变体表中获取信息并将其呈现到特定的基因页面,例如 domain/test_app/genes/TP53。
当我点击 TP53 时,它不会作为基因参数传递到我的视图函数“variant_info”,因为以下行:
variant_info = Variant.objects.filter(gene=gene)
没有从数据库中获取任何信息——我认为当我点击链接时这会传递gene='TP53',因此这将是:
variant_info = Variant.objects.filter(gene='TP53')
这将返回变异表中的信息,基因为 TP53。我不知道如何从views.py 中的基因函数中正确访问TP53。
【问题讨论】:
在 urls.py 中你应该正确地包含正则表达式,例如如果你想通过 id 获取基因:url(r'^genes/(?P<gene>\d+)', views.variant_info, name='variant_info'),
这样基因 id 被传递给视图,那么你应该检索变体这样的对象:variant_info = Variant.objects.filter(gene__id=gene)
我的表中没有基因 ID。主键是基因名
哦,我明白了。这很不常见,无论哪种方式,在 reg exp 中定义要匹配的字符:url(r'^genes/(?P<gene>[^/]+)', views.variant_info, name='variant_info')
然后variant_info = Variant.objects.filter(gene__gene=gene)
基因虽然没有 id - 基因表有基因属性,它是主键 - 而不是增量 id。因为我有一个大型数据库,我最终会合并它不使用唯一的数字 id。因此,我尝试使用我的基因名称(它是变体表中的外键)查询 Variant 表以访问信息,并将其呈现到我的 test_app/genes/TP53 页面。但是,当我单击 TP53 时,它显然不会被继承到 variant_info 函数中,因为在使用 "variant_info = Variant.objects.filter(gene=gene) 时,variant_info 变量为空
【参考方案1】:
对于网址,您需要仅匹配末尾的数字
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)
...
【讨论】:
我想要的是当我点击 TP53 时,这个字符串(“TP53”)通过我的 urls regex r'^genes/(?P问题是您的(?P<gene>)
不匹配任何字符,因此您的视图中始终会出现gene=''
。
尝试将您的网址格式更改为:
url(r'^genes/(?P<gene>\w+)/$', views.variant_info, name='variant_info'),
这将接受字母 A-Z、a-z、数字 0-9 和 gene
参数的下划线。为了与您的其他观点和美元保持一致,我添加了尾部斜杠,因为这样做通常是个好主意。
【讨论】:
以上是关于Django 应用程序视图 - 如何从 url 中的 django 数据库中获取条目并从数据库中获取更多视图信息?的主要内容,如果未能解决你的问题,请参考以下文章
如何从 django 视图中的绝对 url 获取相对 url?