资讯专栏INFORMATION COLUMN

Django城市信息查询功能的实现步骤

89542767 / 478人阅读

  小编写这篇文章的一个目的,主要是用来给大家介绍关于Python Django的一个相关介绍,介绍的内容是涉及到查询功能,比如会教给我们去如何使用相关的城市信息查询功能,那么,具体的其实现步骤是什么呢?下面就给大家详细解答下。


  前言


  基于Pythgo的Django框架,编程实现一个WEB程序,为用户提供城市信息查询功能。用户可输入一个城市名,输出其所在省份名称和邮编等信息。例如,输入“桂林市”,输出“广西壮族自治区”和“541000”等城市相关信息。


  数据准备阶段

01.png

02.png

  版本推荐


  本教程的django为4.0.3,python版本为3.10.4,推荐使用,如果不是这些版本的,django,python会出现错误!

03.png

  项目实现阶段


  Django工程的建立


  在桌面上新建立一个django文件夹,在vscode的终端打开此文件夹,在终端中创建工程项目,如:


 django-admin startproject GongCheng

  可以看到左侧资源管理器左侧出现了GongCheng

04.png

  并在终端运行manager.py文件:

05.png

 

 DesktopdjangoGongCheng>python manage.py runserver


  为项目添加两个App,一个作为主页,一个作为省份查询


  PS C:Users用户DesktopdjangoGongCheng>python manage.py startapp homeApp
  PS C:Users用户DesktopdjangoGongCheng>python manage.py startapp aboutApp


  添加完成后面,对应左边资源管理器:

06.png

  在项目目录下,创建static文件,在此不便多述,上文件链接链接:点击这里下载

07.png

  路由的配置及访问


  在项目路由下的settings.pu文件中的INSTALLED_APPS[]输入两个app的名称:

08.png

  渲染界面


  完成上面的配置后面,打开homeApp文件夹的views.py,使其通过代码返回页面,代码入下:


  from django.shortcuts import render
  from django.shortcuts import HttpResponse
  #Create your views here.
  def home(request):
  return render(request,'home.html')


  然后在homeApp下建立templates文件夹,在该文件夹中建立home.html:

09.png

  并且在html中输入以下代码,使文件与static文件进行连接,获取css,js样式:


  注:有一些人的Django的版本是2.2.4的,小编的Django版本是最新版本的,所以2.2.4版本的同学,需要在HTML的{%load static%}上改为{%load staticfiles%}


  {%load static%}
  <!DOCTYPE html>
  <html>
  <head>
  <meta charset="utf-8">
  <meta http-equiv="X-UA-Compatible"content="IE=edge">
  <meta name="viewport"content="width=device-width,initial-scale=1">
  <title>首页</title>
  <link href="{%static'css/bootstrap.css'%}"rel="stylesheet">
  <link href="{%static'css/style.css'%}"rel="stylesheet">
  <script src="{%static'js/jquery.min.js'%}"></script>
  <script src="{%static'js/bootstrap.min.js'%}"></script>
  </head>
  <body>
  </body>
  </html>


  设置网站根访问路径,在项目根目录找到urls.py找到urlpatterns字段,然后添加首页路由:


  from django.contrib import admin#已经有了
  from django.urls import path#已经有了
  from homeApp.views import home
  from django.conf.urls import include
  urlpatterns=[
  path('admin/',admin.site.urls),
  path('',home,name='home'),
  path('aboutApp/',include('aboutApp.urls')),
  ]

  在aboutApp的目录下创建urls.py,再在aboutAppurls.py里面添加


  from django.urls import path
  from.import views
  app_name='aboutApp'
  urlpatterns=[
  path('about/',views.about,name='about'),
  ]

  使app_name拥有名称。


  打开aboutAppviews.py,输入以下代码:


  from django.shortcuts import render
  from django.shortcuts import HttpResponse
  def about(request):
  html='<html><body>听我说谢谢你</body></html>'
  return HttpResponse(html)
  然后在终端输入:python manage.py runserver运行程序,打开出来的链接


  主页效果:

10.png

  aboutApp页面效果:

11.png

  最后,在根目录的setting.py的INSTALLED_APPS[]上方的ALLOWED_HOSTS=[]添加‘*’:

  ALLOWED_HOSTS=['*',]


  添加富文本模型


  富文本的安装:需要手动安装下载包,下载网址:https://github.com/twz915/DjangoUeditor3/然后安装,终端用cd定义到DjangoUeditor3-master,然后输入以下命令即可完成安装:

  python manage.py install


  需要将DjangoUeditor3-master项目中的DjangoUeditor文件夹加入到当前GongCheng项目根目录中:


  在项目根目录下添加DjangoUeditor

12.png

  添加好文件后,在项目路由下的settings.pu文件中的INSTALLED_APPS[]添加DjangoUeditor

13.png

  在项目根目录找到urls.py找到urlpatterns字段,然后添加富文本路由:

  path('ueditor/',include('DjangoUeditor.urls')),


  在此,完成了富文本的配置


  创建城市与省份模型


  打开aboutApp的models.py文件,在该文件中添加省份模型(Province)
  from django.db import models
  from DjangoUeditor.models import UEditorField
  from django.utils import timezone
  class Province(models.Model):
  name=models.CharField(max_length=10,verbose_name='省份')
  capital=models.CharField(max_length=8,verbose_name='首府')
  concise=UEditorField(u'省份简介',default='',width=800,height=300,)
  class Meta:
  verbose_name='数据'
  verbose_name_plural='数据'
  def __str__(self):
  return self.name
  class City(models.Model):
  province=models.ForeignKey(Province,related_name='city',verbose_name='省份',on_delete=models.CASCADE)
  name=models.CharField(max_length=10,verbose_name="城市")
  mail=models.IntegerField(null=False,verbose_name='邮政编码')
  concise=UEditorField(u'城市简介',default='',width=800,height=300)
  class Meta:
  verbose_name='城市数据'
  verbose_name_plural='城市数据'

  然后在根目录的setting.py添加以下代码:


  import os
  STATICFILES_DIRS=(
  os.path.join(BASE_DIR,"static"),
  )
  MEDIA_URL='/media/'
  MEDIA_ROOT=os.path.join(BASE_DIR,'media/')


  然后在终端输入:python manage.py makemigrations


  回车会看到模型已经建立

14.png

  继续在终端输入;python manage.py migrate


  回车:

15.png

  模型就在后端了。接下来我们注册超级管理员用户,就可以在后台管理系统看到模型了。


  后台管理系统


  因为django自己会建立后台管理系统,所以我们只需要在注册创建管理员用户账号:

  python manage.py createsuperuser


  回车后出现了页面,按照以下输入即可:Username(管理员的账号,自己随意取)

16.png

  通过http://127.0.0.1:8000/admin/进入页面,如果打不开,请在终端输入python manage.py runserver运行程序

17.png

  我们通过账号密码进入后台管理系统后,我们是看不到模型的,我们需要在aboutApp中的admin.py文件,编辑以下代码:


  from django.contrib import admin
  from.models import*
  class Cityline(admin.StackedInline):
  model=City
  extra=1
  class ProvinceAdmin(admin.ModelAdmin):
  inlines=[Cityline,]
  admin.site.register(Province,ProvinceAdmin)
  admin.site.site_header='地市数据'
  admin.site.site_title='地市数据'

  刷新后台界面,我们可以看到模型已经出来了:

18.png

  我们可以浏览一下我们的界面,内部已经覆盖了一对多的模型,富文本文件:

19.png

20.png

  我们可以后台输入数据,然后传到对应页面啦。


  综上所述,这篇文章就给大家介绍到这里了,希望可以给大家带来帮助。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/128426.html

相关文章

  • Python测试开发中Django和Flask框架区别

    摘要:在谈中框架和框架的区别之前,我们需要先探讨如下几个问题。通过大数据统计分析全球著名的网站对和这两个框架的调查分析。从全球著名的代码托管平台上的和数量上分别为,分别为。 在谈Python中Django框架和Flask框架的区别之前,我们需要先探讨如下几个问题。 一、为什么要使用框架? showImg(https://segmentfault.com/img/remote/14600000...

    B0B0 评论0 收藏0
  • 《HelloGitHub》第 68 期

    摘要:整个项目简单还具有实用价值,可作为的实战项目学习的调试工具栏。查看文档自动在个人首页展示编程时长的工具。通过学习这些前沿的人工智能论文,提前了解在未来更多可能性可以将图片和视频转换成漫画风格的工具。兴趣是最好的老师,HelloGitHub 让你对编程感兴趣!简介HelloGitHub 分享 GitHub 上有趣、入门级的开源项目。https://github.com/521xueweihan...

    番茄西红柿 评论0 收藏2637
  • 《HelloGitHub》第 68 期

    摘要:在线尝试的进程管理工具。项目包含了代码实现运行过程动画以及相关论文为系统提供人脸识别解锁电脑的工具。在线阅读教科书计算机体系结构基础第三版。 .markdown-body{word-break:break-word;line-height:1.75;font-weight:400;font-size:15px;overflow-x:hidden;color:#333}.markdown-b...

    番茄西红柿 评论0 收藏2637
  • 爬虫+网站开发实例:电影票比价网

    摘要:注一篇去年的旧文,发现没在知乎发过,过来补个档。于是就有了我们这个小项目电影票比价网在我们这个网页上,会展示出当前热映的电影。涉及到模块主要是用来匹配不同渠道的影院信息代码结构项目主要有三块使用豆瓣每日更新上映的影片列表。 注:一篇去年的旧文,发现没在知乎发过,过来补个档。有个小问题是项目中淘票票的网页反爬提升且变动较多,目前暂不可用了。 时常有同学会问我类似的问题:我已经学完了 Py...

    Codeing_ls 评论0 收藏0
  • django官方文档1.11编翻:1-1-2安装

    摘要:快速安装指南在你使用之前,你需要安装它。安装作为一个框架,需要。这对于大多数用户来说是最好的方法。安装操作系统发行版提供的版本。安装最新的开发版本。那些仅在的开发版本中可用的短语标记功能,并且它们可能不适用于正式版本。 快速安装指南 在你使用Django之前,你需要安装它。 我们有一个完整的安装指南,涵盖所有的可能性; 本指南将引导您进行一个简单的,最小化的安装,这将在您通读介绍时起作...

    LiangJ 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<