目前,我YYMMDD-NAME+PAGE为大多数文件使用了一个名称。NAME有空格转换为下划线。
我想使用YYYY-MM-DD日期格式,但我不确定如何将它与名称分开。-如果名称以数字开头,A看起来会很奇怪。如果我使用 a _,则它与表示空格的下划线冲突。
在这里可以使用的文件名中哪些字符是相当安全的?我使用的是 Linux,但我可能会与其他人(Windows 7、Mac OS X)共享文件。
nau*_*101 70
虽然 RedGrittyBrick 的回答在技术上是正确的,但安全并不是唯一的问题:可用性也很重要。我认为更好的问题是“在文件名中使用哪些字符比较好”。
一些潜在的指导方针:
\/:*?"<>|并且空字节至少在一个系统上有问题,应始终避免。[]()^ #%&!@:+={}'~和[`]在许多 shell 中都具有特殊含义,并且很烦人,因此应避免使用。它们在 URL 中也往往看起来很糟糕。这基本上给你留下了:
使用起来总是安全且不烦人的(只要您以字母数字开头的文件名):)
Red*_*ick 60
概括:
\/:*?"<>|/在所有平台上,最好避免使用不可打印的字符,例如 ASCII 控制字符。
视窗
在 Windows 中,Windows 资源管理器不允许使用控制字符或\/:*?"<>|您可以使用空格。如果您使用空格,则在从命令行使用时通常需要引用文件名(但据我所知,GUI 应用程序不受影响)。Windows 文件系统(如 NTFS)显然使用文件名存储编码,但 UTF-16 是标准的。
Windows 的某些部分区分大小写,其他部分不区分大小写。在 Windows NTFS 文件系统上创建不同的文件名(如“Ab”和“ab”)很容易。这些名称是指包含不同单独内容的单独文件。但是,尽管 Windows 命令提示符很乐意使用 列出这两个文件dir,但您无法使用type. 见下文。
Linux,OS-X
/我相信在 Linux 和 OS-X 中,只有可打印的 ASCII 集是被禁止的。某些字符(如 的 shell 元字符*?!)会导致命令行出现问题,并且需要适当引用或转义文件名。
ext2、ext3 等 Linux 文件系统与字符集无关(我认为他们只是或多或少地将其视为字节流 - 只有空值并且/被禁止)。这意味着您可以以 UTF-8 编码存储文件名。我相信 shell 或其他应用程序知道使用什么编码来正确转换文件名以进行显示或处理。
结论
所以你可能可以安全地使用类似的东西?(如果它不那么难打字)
Windows 中的区分大小写
C> dir /B
Ab
aB
?B
C> type Ab
b
b
C> type aB
b
b
C> type ?B
unicode homograph
Run Code Online (Sandbox Code Playgroud)
请注意,我们不能键入第二个文件的内容,Windowstype命令只返回 Ab 的内容。第三个文件也与 Linux 上的 aB 不同。
(Windows 10 NTFS)。
| 归档时间: |
|
| 查看次数: |
53134 次 |
| 最近记录: |