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 参数。为了与您的其他观点保持一致,我添加了尾部斜杠,并添加了美元,因为这样做通常是个好主意。