ARST打卡第104周[104/521]
Algorithm
Review
TED:在互联网中解放自己
互联网让我们很容易找到和我们观点相同的观点,从而会很容易让我们的思维变得固化僵硬,甚至变得偏激
所以我们需要自己人为的去保持自己的互联网关注的东西多样化,去关注你对立观点中被世人称赞的观点,去思考求证,去保持开放
Tips
Django Template双重嵌套遍历字典嵌字典:Need 2 values to unpack in for loop; got 6.
解决方案
不能仅使用Dict对象来获取信息,可能Dict对象里面有6个字段 然后应该使用Dict对象的 items 属性来获取key和value
|
|
Share-Django如何创建一个文件并将其保存到模型的FileField中
model定义
|
|
详细接口
基本上,一个字段被声明为一个FileField
,当被访问时,给你一个类的实例FieldFile
,它给你几个方法来与底层文件进行交互。所以,你需要做的是:
self.file.save(new_name, new_contents)
new_name你希望分配的文件名在哪里,并且new_contents
是文件的内容。
注意,new_contents
必须是二者之一的一个实例django.core.files.File
或django.core.files.base.ContentFile
(见给出的链接手册的细节)。这两个选择归结为:
|
|
仍可能遇到问题
UnicodeDecodeError: ‘utf-8’ codec can’t decode byte 0x89 in position 0: invalid start byte
搜了一下发现,直接修改一下open为rb就行
最终的views.py中的处理函数
|
|
参考文件
https://cloud.tencent.com/developer/ask/84584 https://docs.djangoproject.com/zh-hans/3.1/ref/models/fields/#django.db.models.FileField https://stackoverflow.com/questions/42339876/error-unicodedecodeerror-utf-8-codec-cant-decode-byte-0xff-in-position-0-in