AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 31913
Accepted
jhayes
jhayes
Asked: 2009-06-26 14:36:38 +0800 CST2009-06-26 14:36:38 +0800 CST 2009-06-26 14:36:38 +0800 CST

附加到文件名的日期时间的正确格式

  • 772

我正在尝试设置一个批处理文件来执行一组存储的过程并将输出转储到带时间戳的文本文件中。我在查找时间戳的正确格式时遇到问题。

这是我正在使用的

osql.exe -S <server> -E -Q "EXEC <stored procedure> " -o "c:\filename_%date:~-0,10%_%time:~-0,10%.txt"

我得到的错误是:

无法打开输出文件 - x:\filename_Thu 06/25/_16:26:43.1.txt 没有这样的文件或目录

我找不到文档,我已经玩过它,但找不到正确的格式。

windows
  • 3 3 个回答
  • 1375 Views

3 个回答

  • Voted
  1. John Gardeniers
    2009-06-26T21:37:03+08:002009-06-26T21:37:03+08:00

    我建议您使用更传统的日期格式,这也有助于轻松排序 - yyyymmddhhmmss。即根本不要使用分隔符。当你第一次看到这样的格式时,它可能看起来很难阅读,但你会在大约 2.5 秒内克服它。

    • 2
  2. Best Answer
    Kjetil Joergensen
    2009-06-26T14:41:38+08:002009-06-26T14:41:38+08:00

    : 不是 Windows 上文件名中的有效字符(以及“\ / * ? < > 和 |),我猜 %time 的扩展包含 : 的分隔小时、分钟和秒。

    黑暗中的刺可能会用以下内容替换 %time:~0,10%:

    %time:~0,2%_%time:~3,2%_%time:~6,2%
    

    这假设 %time% 总是采用“hh:mm:ss.ss”的形式,我认为这取决于您的语言环境(即我的语言环境使用 a ,而不是 . 来分隔秒和 1/100 秒) . 它应该给你类似 hh_mm_ss 而不是 hh:mm:ss 的东西。如果您想要 1/100 秒的第一个数字(就像您在原始示例中所使用的那样),您可以将最后一个变量扩展更改为采用字符范围 6,4 而不是 6,2。

    所以,乍一看,我忽略了 / 在文件名中也是无效的,你可能也想删除它们。假设 %date% 将采用“ddd DD/MM/yyyy”格式,您可以尝试类似(我的语言环境与此不同,因此未经测试):

    %date:~4,2%_%date:~7,2%_%date:~10,4%
    

    为了测试所有这些,如果您还没有这样做,我建议您打开 cmd.exe 并在其中输入它。“回声 %time:~0,2%etc.etc.” 找到适合您所在地区的东西。

    最后,警告一句,这基本上假设一个特定的语言环境,它不太可能移植到不同的语言环境。

    • 1
  3. KAPes
    2009-06-28T19:51:34+08:002009-06-28T19:51:34+08:00

    如果你想要日期的通用格式,试试这个。

    for /F "skip=1 tokens=2-4 delims=(-)" %%A in ('echo ^| date') do for /F "Tokens=2-4 Delims=/ " %%X in ('date /t') do set %%A=%%X & set %%B=%%Y & set %%C=%%Z
    
    echo today is %dd%%mm%%yy%
    

    这对于遵循不同日期格式的服务器非常有用,例如 mm/dd/yyyy 或 dd/mm/yyyy 这将始终确保您获得变量 mm 中的月份、dd 中的日期和 yy 中的年份

    • 1

相关问题

  • 您最喜欢的云计算提供商是什么?[关闭]

  • Vanilla Powershell 是否足以成为 Windows 和 DB 服务器管理员的语言?

  • 为什么添加新驱动器后我的磁盘驱动器访问速度如此之慢?

  • 在 Windows Server 2003 下使用 wscipt 从 .asp 文件运行 .exe

  • 最佳混合环境(OS X + Windows)备份?[关闭]

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    从 IP 地址解析主机名

    • 8 个回答
  • Marko Smith

    如何按大小对 du -h 输出进行排序

    • 30 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    Windows 中执行反向 DNS 查找的命令行实用程序是什么?

    • 14 个回答
  • Marko Smith

    如何检查 Windows 机器上的端口是否被阻塞?

    • 4 个回答
  • Marko Smith

    我应该打开哪个端口以允许远程桌面?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    MikeN 在 Nginx 中,如何在维护子域的同时将所有 http 请求重写为 https? 2009-09-22 06:04:43 +0800 CST
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    0x89 bash中的双方括号和单方括号有什么区别? 2009-08-10 13:11:51 +0800 CST
  • Martin Hope
    kch 如何更改我的私钥密码? 2009-08-06 21:37:57 +0800 CST
  • Martin Hope
    Kyle Brandt IPv4 子网如何工作? 2009-08-05 06:05:31 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve