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?
我有一个 django 应用程序 'test_app'。 test_app 页面 - "domain/test_app/" 有一个 link 到应用 "Genes" 中的另一个页面。这将我带到 "domain/test_app/genes/"。在此页面中,我有一个 link 列表,它来自我的 django 数据库中的一个 table,名为 "gene",它在 test_app/models.py 中作为 [=56= 】 基因。此 link 通过属性 'gene' 作为外键传给另一个名为 "Variants" 的 table。
这一切都在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 看起来像这样(link 到 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}
我的数据库中有一个基因列表 table。使用 'gene_list = Gene.objects.all()' 获取这些基因时,效果很好。然后,我将此列表呈现为模板,作为我的 "domain/test_app/genes" 页面上的一系列 link。例如,当我在这个页面上点击 TP53 时,它会转到 "domain/test_app/genes/TP53/"。这会将我带到正确的页面。
但是,我显然没有正确的此 urlpattern 的正则表达式,因为当我输入更多数字或字符(例如 /TP53098120918)时,它仍然会转到同一页面。即使当我输入 r'^genes/(?P)$' 时,这种情况仍在发生,我不明白为什么?
但我遇到的主要问题是从我的数据库中的变体 table 获取信息并将其呈现到特定基因页面,例如 domain/test_app/genes/TP53。
当我点击 TP53 时,它不会作为基因参数传递到我的视图函数 'variant_info',因为行:
variant_info = Variant.objects.filter(gene=gene)
没有从数据库中获取任何信息 - 我认为当我点击 link 时这将通过 gene='TP53',因此这将是:
variant_info = Variant.objects.filter(gene='TP53')
这将 return 来自变体 table 的信息,其基因为 TP53。我不知道如何从 views.py 中的基因功能正确访问 TP53。
对于 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)
...
问题是您的 (?P<gene>)
没有匹配任何字符,因此您的视图中将始终显示 gene=''
。
尝试将您的 url 模式更改为:
url(r'^genes/(?P<gene>\w+)/$', views.variant_info, name='variant_info'),
这将接受字母 A-Z、a-z、数字 0-9 和下划线作为 gene
参数。为了与您的其他观点保持一致,我添加了尾部斜杠,并添加了美元,因为这样做通常是个好主意。
我有一个 django 应用程序 'test_app'。 test_app 页面 - "domain/test_app/" 有一个 link 到应用 "Genes" 中的另一个页面。这将我带到 "domain/test_app/genes/"。在此页面中,我有一个 link 列表,它来自我的 django 数据库中的一个 table,名为 "gene",它在 test_app/models.py 中作为 [=56= 】 基因。此 link 通过属性 'gene' 作为外键传给另一个名为 "Variants" 的 table。
这一切都在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 看起来像这样(link 到 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}
我的数据库中有一个基因列表 table。使用 'gene_list = Gene.objects.all()' 获取这些基因时,效果很好。然后,我将此列表呈现为模板,作为我的 "domain/test_app/genes" 页面上的一系列 link。例如,当我在这个页面上点击 TP53 时,它会转到 "domain/test_app/genes/TP53/"。这会将我带到正确的页面。
但是,我显然没有正确的此 urlpattern 的正则表达式,因为当我输入更多数字或字符(例如 /TP53098120918)时,它仍然会转到同一页面。即使当我输入 r'^genes/(?P)$' 时,这种情况仍在发生,我不明白为什么?
但我遇到的主要问题是从我的数据库中的变体 table 获取信息并将其呈现到特定基因页面,例如 domain/test_app/genes/TP53。
当我点击 TP53 时,它不会作为基因参数传递到我的视图函数 'variant_info',因为行:
variant_info = Variant.objects.filter(gene=gene)
没有从数据库中获取任何信息 - 我认为当我点击 link 时这将通过 gene='TP53',因此这将是:
variant_info = Variant.objects.filter(gene='TP53')
这将 return 来自变体 table 的信息,其基因为 TP53。我不知道如何从 views.py 中的基因功能正确访问 TP53。
对于 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)
...
问题是您的 (?P<gene>)
没有匹配任何字符,因此您的视图中将始终显示 gene=''
。
尝试将您的 url 模式更改为:
url(r'^genes/(?P<gene>\w+)/$', views.variant_info, name='variant_info'),
这将接受字母 A-Z、a-z、数字 0-9 和下划线作为 gene
参数。为了与您的其他观点保持一致,我添加了尾部斜杠,并添加了美元,因为这样做通常是个好主意。