Python 从PostgreSQL获取数据到Django,并以html格式显示

Python 从PostgreSQL获取数据到Django,并以html格式显示,python,django,postgresql,Python,Django,Postgresql,我在PostgreSQL数据库中有一个表,它包含两列ID和Name。我正在使用django框架从数据库中获取数据,并希望将数据显示到html页面中。问题是检索到的数据没有列名称。它看起来是这样的,为了在html页面中使用它,它必须为每个元组设置一个键 [(2, 'abc'), (3, 'subhi')] 我试图获取列名称,但它们只是没有数据的表列。下面是我的代码: models.py import psycopg2 import pprint def main(): conn_st

我在PostgreSQL数据库中有一个表,它包含两列ID和Name。我正在使用django框架从数据库中获取数据,并希望将数据显示到html页面中。问题是检索到的数据没有列名称。它看起来是这样的,为了在html页面中使用它,它必须为每个元组设置一个键

[(2, 'abc'), (3, 'subhi')] 
我试图获取列名称,但它们只是没有数据的表列。下面是我的代码:

models.py

import psycopg2
import pprint

def main():
    conn_string = "host='localhost' dbname='music' user='postgres' password='subhi123'"

    column_names = []
    data_rows = []

    with psycopg2.connect(conn_string) as connection:
        with connection.cursor() as cursor:
            cursor.execute("select id, name from music")
            column_names = [desc[0] for desc in cursor.description]
            for row in cursor:
                data_rows.append(row)
                records = cursor.fetchall()

                # print out the records using pretty print
                # note that the NAMES of the columns are not shown, instead just indexes.
                # for most people this isn't very useful so we'll show you how to return
                # columns as a dictionary (hash) in the next example.
                pprint.pprint(records)
                print (type(records))

    print("Column names: {}\n".format(column_names))



if __name__ == "__main__":
    main()
views.py

from django.http import Http404

from django.shortcuts import render
from  .models import main


def index (request):
    all_albums = main()
    return  render(request,'music/index.html',{ 'all_albums' :all_albums})
index.html

{%  if all_albums  %}

<ul>
    {%  for album in all_albums  %}
    <li> <a href="/music/{{ album}}/">{{ album }}</a></li>
    {% endfor %}
</ul>

{% else %}
<h3> You don't have any data</h3>

{%  endif %}
django对db使用ORM(对象相关映射)。它在django中被称为
Model

这意味着,您应该为您的db表和方案创建
Model
类,django会自动为模型创建
sql
——因此,在需要之前,您不会执行sql作业

下面是模型的示例。(文档中的示例)

Django创建数据库表,如

CREATE TABLE myapp_person (
    "id" serial NOT NULL PRIMARY KEY,
    "first_name" varchar(30) NOT NULL,
    "last_name" varchar(30) NOT NULL
);
答案很难全部解释,所以你必须看看django官方文件。在学习了教程(写得很好!)之后,你就可以理解django了——所以至少要学习教程

这里有一些网站需要帮助

  • -强烈推荐

  • -非常好的教程,支持多种语言


您应该使用Django模块,即models.py(由Django.db.models.Model继承)。此模块根据您的选择创建数据字段,并在不带字符串的情况下键入“python manage.py migrate”按enter键时将其迁移到数据库(在您的情况下为Postgresql)。可能由于这个事实,您无法从数据库中获得任何信息。

您没有使用Django从数据库中检索数据。看看您的文件
models.py
,您没有从Django导入任何东西,只导入了
psycopg2
,这是众所周知的用于Python的PostgreSQL连接器。您从中复制/粘贴了此代码,因此请遵循注释中的建议,阅读下一部分,标题为
Select/Fetch Records with Column Names
@Antwane如何使用django从数据库检索数据?我是django的初学者
from django.db import models

class Person(models.Model):
    first_name = models.CharField(max_length=30)
    last_name = models.CharField(max_length=30)
CREATE TABLE myapp_person (
    "id" serial NOT NULL PRIMARY KEY,
    "first_name" varchar(30) NOT NULL,
    "last_name" varchar(30) NOT NULL
);