使用格式字符串语法编写高级文件名模式。
项目描述
使用格式字符串语法编写高级文件名模式。
入门指南
安装
pip install django-dynamic-filenames
示例
基本示例
from django.db import models
from dynamic_filenames import FilePattern
upload_to_pattern = FilePattern(
filename_pattern='{app_label:.25}/{model_name:.30}/{uuid:base32}{ext}'
)
class FileModel(models.Model):
my_file = models.FileField(upload_to=upload_to_pattern)
自动slug示例
功能
字段名称
- ext
文件扩展名,包括点。
- name
文件名,不包括文件夹。
- model_name
Django模型名称。
- app_label
Django模型的应用标签。
- instance
在保存之前的模型实例。此时您可能没有主键。
- uuid
支持多个类型指定的UUID版本4。如果在同一字符串中使用两次,UUID将是相同的,但在每次调用upload_to可调用时将是不同的。
类型指定符允许您以不同的方式格式化UUID,例如{uuid:x}将给出十六进制UUID。
支持的类型指定符包括
- s
带有连字符的UUID字符串表示。
- i
UUID的整数表示。类似于 UUID.int。
- x
UUID的十六进制(基16)表示。类似于 UUID.hex。
- X
UUID的大写十六进制表示。类似于 UUID.hex。
- base32
无填充的UUID的Base32表示。
- base64
无填充的UUID的Base64表示。
所有类型指定器也支持字符串截断精度,例如 {{uuid:.2base32}} 将仅返回Base32编码UUID的前两个字符。
类型指定器
您还可以使用特殊的slug类型指定器,该指定器将字符串转换为slug。
示例
from django.db import models
from dynamic_filenames import FilePattern
upload_to_pattern = FilePattern(
filename_pattern='{app_label:.25}/{model_name:.30}/{instance.title:.40slug}{ext}'
)
class FileModel(models.Model):
title = models.CharField(max_length=100)
my_file = models.FileField(upload_to=upload_to_pattern)
Slug类型指定器也支持字符串截断精度。在上面的示例中,实例标题的slug将在40个字符处截断。
项目详情
下载文件
下载适合您平台的文件。如果您不确定选择哪个,请了解更多关于 安装包 的信息。
源分布
django-dynamic-filenames-1.3.2.tar.gz (10.0 kB 查看散列)
构建分布
关闭
django-dynamic-filenames-1.3.2.tar.gz的散列
算法 | 散列摘要 | |
---|---|---|
SHA256 | 07c2f047fbb76c02f153305d53fdd95890cdbd5690072c7109a5638d4b456989 |
|
MD5 | 76a630cbba67a2392a29d99398499c9d |
|
BLAKE2b-256 | 6621983489a524a506e360336fd0d1846edd404b10ac3b89192009256c569563 |
关闭
django_dynamic_filenames-1.3.2-py2.py3-none-any.whl的散列
算法 | 散列摘要 | |
---|---|---|
SHA256 | a78cb1a7b3642dc57c14ef8cc345894d988a4453ca6125292cefd3c328450417 |
|
MD5 | 7718bd92cfa662d6bc03862baa8b087f |
|
BLAKE2b-256 | 59de9904ac45bd2b3a62a6bc4853bf8896c1383c07c248676538b9e65ab6a4d9 |