本篇概述

  Django Admin后台显示 多对多字段(如何)

  Django 模板 显示 多对多字段(如何)

  Django 将表单中上传的多对多字段存入数据库 (如何)

    Django 上传文件 (如何)

models代码背景

 class Tag(models.Model):
name = models.CharField(max_length=20, verbose_name="名称") class work(models.Model):
Tag = models.ManyToManyField(Tag, verbose_name="标签")

一,Django Admin后台显示 多对多字段

  于admin.py文件中

 @admin.register(work)
class workAdmin(admin.ModelAdmin):
'''展示tags'''
def show_tags(self, obj):
return [tag.name for tag in obj.Tag.all()]
# 这里运用了Python的堆导式
show_tags.short_description = "标签" # 设置表头
list_display = ["show_tags"]

二,Django 模板 显示 多对多字段

   先与 视图 views.py文件中

 class IndexView(View):
def get(self, request):
works = work.objects.all()[:2] context = {
'works': works,
}
return render(request, 'index.html', context)

  然后,(urls.py中的配置就不多说了,直接进如何在模板中取得)

 {% for work in works %}
{% for tag in work.Tag.all %}
{# 下面即 该作品对应的标签 #}
{{tag.name}}
{% endfor %}
{% endfor%}

三,Django 将表单中上传的多对多字段存入数据库

  1、首先获取表单中上传的多对多数据,假设 上传的 标签(多)且 标签与作品 work 的关系是 ManyToManyField

 # 标签
tag = request.POST.getlist("tag")

  2、创建一个 work 对象 然后 进行数据的交互

 works = work()
works.save()
# 多对多字段存入
for tags in tag:
id = Tag.objects.get(name=tags).id
works.Tag.add(id)
works.save()

  当然这必须是 数据库中 Tag 要有的标签名称才行,不然找不到 id 无法存入,因为 add()方法就是的参数是 id,至于非标签已有存入 有待 摸索~~

四,Django上传文件,如何

  1.  首先与 settings.py文件中增添

 # 上传文件

 MEDIA_ROOT = os.path.join(BASE_DIR, r'static\upfile')

  2、于 模板 表单中 添加 input:file + tap 。。。

 <input type="file" name="file">

  3、修改 form 表单属性

 method="post"   方法必须是 post
enctype="multipart/form-data" 上传文件必备

  4、与视图Views.py文件中

 # 这里 Django视图函数,我用的基于类的视图
# 例如 class AddView(View)
# 在其中
def post(self, request):
try:
f = request.FILES["file"]
# 合成文件在服务器端的路径
filePaths = "static/upfile/" + f.name # 这里的原因:如果是在分页中,文件路径会额外添加如 /page_id/ 导致后面调用失败,根据个人情况进行合理调整
filePath = os.path.join(settings.MEDIA_ROOT, f.name)
print(filePath)
with open(filePath, 'wb') as fp:
# 以文件流的形式一段段上传
for info in f.chunks():
fp.write(info)
except:
return HttpResponse("上传失败")

  5、然后 进行上传,大功告成 ~~

Django 注意知识点(一)的更多相关文章

  1. 关于Django查询知识点总结

    ========关于Django查询知识点总结======= models.Book.objects.filter(**kwargs): querySet [obj1,obj2] models.Boo ...

  2. Django项目知识点汇总

    目录 一.wsgi接口 二.中间件 三.URL路由系统 四.Template模板 五.Views视图 六.Model&ORM 七.Admin相关 八.Http协议 九.COOKIE 与 SES ...

  3. Django补充知识点——用户管理

    内容概要 1.Form表单2.Ajax3.布局,Django母板4.序列化5.Ajax相关6.分页7.XSS攻击8.CSRF9.CBV.FBV 10.类中用装饰器的两种方法 11.上传文件 12.数据 ...

  4. django 之知识点总结以及Form组件

    一.model常用操作 1.13个API查询:all,filter,get ,values,values_list,distinct,order_by ,reverse , exclude(排除),c ...

  5. day64 django django零碎知识点整理

    本文转载自紫金葫芦,哪吒,liwenzhou.cnblog博客地址 简单了解mvc框架和MTV框架, mvc是一种简单的软件架构模式: m----model,模型 v---view,视图 c---co ...

  6. Django框架知识点整理

    1.安装django, pip install django 或者是通过 “==”符号指定版本号. 2.创建一个Django项目: django-admin createproject project ...

  7. [django]drf知识点梳理-权限

    用户 - 权限 - 资源 (拥有) (绑定) django权限机制能够约束用户行为,控制页面的显示内容,也能使API更加安全和灵活:用好权限机制,能让系统更加强大和健壮 django权限控制 Djan ...

  8. [django]drf知识点梳理-搜索

    什么是搜索? 譬如http://127.0.0.1:8000/User/?username=maotai-0 可以检索出想要的. 自己实现原始的搜索 重写下get_queryset方法 class U ...

  9. [django]drf知识点梳理-分页

    msyql分页 limit offset https://www.cnblogs.com/iiiiiher/articles/8846194.html django自己实现分页 https://www ...

  10. Django小知识点整理

    一.Django中Choices字段显示中文的两种方式 1.get_xxxx_display():这种方式只能针对对象来使用 {% for row in server_list %} <li&g ...

随机推荐

  1. JS---案例:点击按钮摇起来 & 星星闪动 (挺难看的)

    案例1:点击按钮摇起来 思路: 1. 2张图片,放进div里面,摇起来的本质是,此div按上下左右的位置和在一定的时间内发生移动 2. 所以用随机数的概念来实现位置的移动,用setInterval来实 ...

  2. JSON2ABAPType:根据JSON数据结构生成ABAP类型定义

    一图表明本文将要介绍的工具: JSON是常见的数据格式,经常用于接口开发.ABAP开发者通常使用/ui2/cl_json来把JSON数据转换为相应的ABAP类型. 在转换前,必须要定义相应的ABAP类 ...

  3. Xamarin.Forms 界面布局

    <!--margin表示控件相对StackLayout的位置是设置组件之间的距离,或者距离父组件边缘的距离,    他的四个值是左边距,上边距,右边距,下边距  -->    <!- ...

  4. kafka2.3.1+zookeeper3.5.6+kafka-manager2.0.0.2集群部署(centos7.7)

    一.准备三台服务器,配置好主机名和ip地址 二.服务器初始化:包括安装常用命令工具,修改系统时区,校对系统时间,关闭selinux,关闭firewalld,修改主机名,修改系统文件描述符,优化内核参数 ...

  5. 使用PHP生成并导出CSV文件

    CSV文件是以纯文本形式存储的,一般以逗号为分隔符.这里主要简单介绍下如何导出CSV文件. 一.浏览器导出CSV文件格式 /** * 导出CSV文件 */ function exportCsv() { ...

  6. Mysql 主从复制搭建-极简版

    前言 自己在百度.Google一番踩坑搭建成功后,记录一下,也希望后来人不再被这些坑到. 这里为了方便使用 docker,不会的同学请移步相关 Docker 教程. 正文 1. 启动 mysql #启 ...

  7. WPF之实现控件内容拖动

    以下分别记录label.listbox.treeview三个控件的拖动示例: 1.对被拖动控件,实现拖动事件,主要是通过各种鼠标事件,实现DragDrop.DoDragDrop方法. 2.对于需要拖动 ...

  8. Java每日一面(Part2数据库)[19/11/28]

    作者:故事我忘了¢个人微信公众号:程序猿的月光宝盒 1.如何设计一个关系型数据库 如上图,首先划分成两大部分: ​ 1.存储部分:类似一个文件系统,把数据存储到一个持久化设备中,如机械硬盘,固态等 ​ ...

  9. 50-overlay 如何实现跨主机通信?

    上一节我们在 host1 中运行了容器 bbox1,今天将详细讨论 overlay 网络跨主机通信的原理. 在 host2 中运行容器 bbox2: bbox2 IP 为 10.0.0.3,可以直接 ...

  10. 将Excel表结构导入到Powerdesigner

    我们经常会在excel中设计整理表结构,整理完需要导入到Powerdesigner中,可以通过以下脚本来实现快速,具体操作方法: 打开PowerDesigner,新建模型,点击Tools|Execut ...