Python提供了生成临时文件名的功能,请参见http://docs.python.org/library/tempfile.html。例如:
In [4]: import tempfile
tempfile.NamedTemporaryFile()
的每次调用都会生成一个不同的临时文件,并且可以通过 .name
属性访问其文件名,例如:
In [5]: tf = tempfile.NamedTemporaryFile()
In [6]: tf.name
Out[6]: 'c:\\blabla\\locals~1\\temp\\tmptecp3i'
In [7]: tf = tempfile.NamedTemporaryFile()
In [8]: tf.name
Out[8]: 'c:\\blabla\\locals~1\\temp\\tmpr8vvme'
一旦你拥有了独特的文件名,它可以像任何普通文件一样使用。注意:默认情况下,当文件关闭时,它会被删除。然而,如果delete
参数为False,则文件不会自动删除。
完整参数集:
tempfile.NamedTemporaryFile([mode='w+b'[, bufsize=-1[, suffix=''[, prefix='tmp'[, dir=None[, delete=True]]]]]])
在文件创建过程中,可以通过提供多个参数之一来指定临时文件的前缀:
In [9]: tf = tempfile.NamedTemporaryFile(prefix="zz")
In [10]: tf.name
Out[10]: 'c:\\blabla\\locals~1\\temp\\zzrc3pzk'
在此处可以找到有关使用临时文件的其他示例:这里
常见的做法是将时间戳作为文件名前缀/后缀,以便与该文件建立一些时间上的关系。如果需要更多的唯一性,仍然可以添加一个随机字符串。
import datetime
basename = "mylogfile"
suffix = datetime.datetime.now().strftime("%y%m%d_%H%M%S")
filename = "_".join([basename, suffix]) # e.g. 'mylogfile_120508_171442'
1. 检查文件是否存在;2. 创建文件
。如果在你的代码执行步骤1和步骤2之间被其他进程打断,并且这个进程创建了该文件,那么当你的代码恢复时,它将会覆盖该进程创建的文件。 - Li-aung Yiptempfile
模块,它会为你处理这个问题。 :) - Li-aung Yip...strftime("%y%m%d_%H%M%S%f")
。 - AstraSerg如果你只需要预定义长度的随机字符串,而不是文件路径,你可以使用类似以下的代码:
>>> import random
>>> import string
>>> file_name = ''.join(random.choice(string.ascii_lowercase) for i in range(16))
>>> file_name
'ytrvmyhkaxlfaugx'
该OP请求创建随机的文件名,而不是随机的文件。时间和UUID可能会发生冲突。如果您在单个计算机上工作(而不是共享文件系统),并且您的进程/线程不会互相干扰,则使用os.getpid()
获取自己的PID,并将其用作唯一文件名的一个元素。其他进程显然不会得到相同的PID。如果您使用多线程,则需要获取线程ID。如果您的代码有其他方面,其中单个线程或进程可以生成多个不同的临时文件,则可能需要使用另一种技术。滚动索引可以运作(如果您不会保留它们太久或使用太多文件而担心翻转)。在这种情况下,保持全局哈希/索引以便于“活动”文件就足够了。
非常抱歉解释得有些冗长,但这确实取决于您的确切用途。
如果您想将原始文件名作为新文件名的一部分保留下来,可以通过使用当前时间的MD5哈希值生成相同长度的唯一前缀:
from hashlib import md5
from time import localtime
def add_prefix(filename):
prefix = md5(str(localtime()).encode('utf-8')).hexdigest()
return f"{prefix}_{filename}"
a38ff35794ae366e442a0606e67035ba_style.css
7a5f8289323b0ebfdbc7c840ad3cb67b_style.css
在这里添砖加瓦:
In [19]: tempfile.mkstemp('.png', 'bingo', '/tmp')[1]
Out[19]: '/tmp/bingoy6s3_k.png'
In [20]: os.path.exists(tempfile.mkstemp('.png', 'bingo', '/tmp')[1])
Out[20]: True
import uuid
imageName = '{}{:-%Y%m%d%H%M%S}.jpeg'.format(str(uuid.uuid4().hex), datetime.now())
import hashlib
image_path = '/tmp/my_image.png'
with open(image_path, 'rb') as f:
image_bytes = f.read()
file_name = f'{hashlib.sha256(image_bytes).hexdigest()}.png'
with open(filename, 'wb') as ff:
ff.write(image_bytes)
如果以下情况适用于您,请使用此方法:
如果您保存的文件几乎肯定永远不会产生相同的SHA值,那么此方法对您也几乎没有好处。但是,如果您需要保存数千个文件并确保它们不被覆盖(除了重复文件),此方法仍然可能有用。
我个人希望我的文本不仅是随机/独特的,而且也要美观,这就是我喜欢hashids库的原因,它可以从整数生成漂亮的随机文本。
可以通过pip install hashids
进行安装。
代码片段:
import hashids
hashids = hashids.Hashids(salt="this is my salt", )
print hashids.encode(1, 2, 3)
>>> laHquq
简要描述:
Hashids是一个小型的开源库,可以从数字中生成短、唯一、非连续的ID。
uuid.uuid4().hex
来获取没有短横线(-
)的十六进制字符串。 - Rockallite