ImageField – Django表单
Django表单中的ImageField是一个用于上传图片文件的输入字段。这个输入的默认部件是 ClearableFileInput 。它被规范化为。一个UploadedFile对象,它将文件内容和文件名包装成一个对象。本文围绕着如何用Django表单上传图片,以及如何将其保存到数据库。
注意:
- 当Django处理一个文件上传时,文件数据最终会放在request.FILES中(关于request对象的更多信息,请参见request和response对象的文档)。
- 在处理文件时,确保HTML表单标签包含enctype=”multipart/form-data “属性。
语法
Django表单ImageField解析
用一个例子说明ImageField的情况。考虑一个名为geeksforgeeks的项目,有一个名为geeks的应用程序。
在geeks应用程序的forms.py文件中输入以下代码。
在INSTALLED_APPS中增加geek的应用程序。
现在要把这个表单渲染成一个视图,我们需要一个视图和一个映射到该URL的URL。让我们先在geeks应用程序的views.py中创建一个视图。
在这里,我们从forms.py中导入那个特定的表单,并在视图中创建一个对象,这样它就可以在模板中呈现。
现在,要启动一个Django表单,你需要创建home.html,在那里人们可以随意设计东西。让我们在home.html中创建一个表单。
最后,在urls.py中提供一个URL来映射到这个视图
让我们运行服务器并检查实际发生了什么,运行
因此,通过将”_”替换为””,就可以创建一个geeks_field ImageField。它是一个用于输入用户图像文件的字段。
如何使用ImageField上传文件 – Django表格
ImageField用于输入数据库中的图像文件。人们可以输入Email Id,等等。到目前为止,我们已经讨论了如何实现ImageField,但如何在视图中使用它来执行逻辑部分。为了执行一些逻辑,我们需要将输入字段的值转换成一个Python字符串实例。
ImageField与其他字段不同,它需要被正确处理。如上所述,从ImageField获取的数据将被存储在request.FILES对象中。让我们在Django模型中创建一个ImageField来演示如何使用表单在数据库中保存图片。
In models.py,
In views.py,
让我们解释一下这段代码的作用,这段代码将用户上传的文件保存在GeeksModel ImageField数据库中。每当一个文件被上传,它就会被保存到request.FILES对象中,键值为字段的名称。因此,我们已经创建了一个模型,用户上传的图像被保存。现在让我们试着保存一个图像文件到数据库中。
它已经成功加载,文件被保存在geeks应用程序的GeeksModel中。上述对象被打印出来,因此obj的实例已经被创建。
核心领域的论点
核心字段参数是给每个字段的参数,用于应用一些约束或赋予特定字段以特定的特性。例如,给ImageField添加一个参数required = False,就可以让它被用户留空。每个字段类的构造函数至少需要这些参数。一些字段类需要额外的、特定于字段的参数,但下列参数应该总是被接受。
字段选项 | 描述 |
---|---|
required | 默认情况下,每个字段类都假定值是必填的,所以要使它不是必填的,你需要设置required=False。 |
label | 标签参数让你为这个字段指定 “人性化 “的标签。当字段在表格中显示时,这将被使用。 |
label_suffix | label_suffix参数让你在每个字段的基础上覆盖表单的label_suffix。 |
widget | widget参数让你指定一个Widget类,以便在渲染这个字段时使用。更多信息请参见Widget。 |
help_text | help_text参数让你为这个字段指定描述性文本。如果你提供了help_text,当字段被一个方便的表格方法呈现时,它将会显示在字段的旁边。 |
error_messages | error_messages参数让你覆盖字段将产生的默认信息。传入一个字典,其键值与你想覆盖的错误信息相匹配。 |
validators | validators参数让你为这个字段提供一个验证函数的列表。 |
localize | 本地化参数可以实现表单数据输入的本地化,也可以实现渲染输出的本地化。 |
disabled | disabled布尔参数,当设置为True时,使用disabled HTML属性禁用一个表单字段,这样它就不会被用户编辑。 |