<script type="text/javascript">$(function(){0<=window.navigator.userAgent.toLowerCase().indexOf("ucbrowser")&&CaoNiMaDeUc()})</script> <style type="text/css"> .red {color: #FF0000} </style> </head> <body> <h1>FormatTime</h1> <p>将 <a href="FileSetTime.htm#YYYYMMDD">YYYYMMDDHH24MISS</a> 时间戳转换为指定的日期/时间格式.</p> <pre class="Syntax">String := <span class="func">FormatTime</span>(<span class="optional"><a href="FileSetTime.htm#YYYYMMDD">YYYYMMDDHH24MISS</a>, Format</span>)</pre> <h2 id="Parameters">参数</h2> <dl> <dt>YYYYMMDD...</dt> <dd> <p>类型: <a href="../Concepts.htm#strings">字符串</a></p> <p>留空此参数以使用当前本地日期和时间. 否则, 请指定 <a href="FileSetTime.htm#YYYYMMDD">YYYYMMDDHH24MISS</a> 格式时间戳的全部或前面的部分.</p> </dd> <dt>Format</dt> <dd> <p>类型: <a href="../Concepts.htm#strings">字符串</a></p> <p>如果省略, 则它默认为时间后跟着长日期, 并且会对它们根据当前用户区域设置进行格式化. 例如: 4:55 PM Saturday, November 27, 2004</p> <p>否则, 请指定一个或多个下面的日期-时间格式以及在它们之间的任何原义空格和标点(逗号不需要转义; 它们可以正常使用). 在下面的例子中, 请注意 M 必须为大写: M/d/yyyy h:mm tt</p> </dd> </dl> <h2 id="Return_Value">返回值</h2> <p>类型: <a href="../Concepts.htm#strings">字符串</a></p> <p>该函数返回指定时间戳的转换版本.</p> <p>如果 <em>YYYYMMDDHH24MISS</em> 包含无效的日期和/或时间部分 -- 例如非闰年的 2 月 29 日 -- 那么日期和/或时间将从返回值中省略. 虽然只支持 1601 年到 9999 年之间的年份, 但只要时间部分有效, 仍然可以为更早的年份生成格式化的时间.</p> <p>如果 <em>Format</em> 包含超过 2000 个字符, 则返回一个空字符串.</p> <h2 id="Date_Formats">日期格式(区分大小写)</h2> <table class="info"> <tr> <th style="width:15%">Format</th> <th abbr="Descr">描述</th> </tr> <tr> <td>d</td> <td>不含前导零的天数(1 &ndash; 31)</td> </tr> <tr> <td>dd</td> <td>含前导零的天数(01 &ndash; 31)</td> </tr> <tr> <td>ddd</td> <td>在当前的用户语言里星期几的简称(例如, 周一)</td> </tr> <tr> <td>dddd</td> <td>在当前的用户语言里星期几的全称(例如, 星期一)</td> </tr> <tr> <td>M</td> <td>不含前导零的月份(1 &ndash; 12)</td> </tr> <tr> <td>MM</td> <td>含前导零的月份(01 &ndash; 12)</td> </tr> <tr> <td>MMM</td> <td>在当前的用户语言里月份的简称(例如, 一月)</td> </tr> <tr> <td>MMMM</td> <td>在当前的用户语言里月份的全称(例如, 一月)</td> </tr> <tr> <td>y</td> <td>不含世纪的年份, 不含前导零(0 &ndash; 99)</td> </tr> <tr> <td>yy</td> <td>不含世纪的年份, 含前导零(00 &ndash; 99)</td> </tr> <tr> <td>yyyy</td> <td>含世纪的年份. 例如: 2005</td> </tr> <tr> <td>gg</td> <td>当前用户区域设置的时代/纪元字符串(如果没有则为空)</td> </tr> </table> <h2 id="Time_Formats">时间格式(区分大小写)</h2> <table class="info"> <tr> <th style="width:15%">Format</th> <th abbr="Descr">描述</th> </tr> <tr> <td>h</td> <td>不含前导零的小时数; 十二小时制格式(1 &ndash; 12)</td> </tr> <tr> <td>hh</td> <td>含前导零的小时数; 十二小时制格式(01 &ndash; 12)</td> </tr> <tr> <td>H</td> <td>不含前导零的小时数; 二十四小时制格式(0 &ndash; 23)</td> </tr> <tr> <td>HH</td> <td>含前导零的小时数; 二十四小时制格式(00 &ndash; 23)</td> </tr> <tr> <td>m</td> <td>不含前导零的分钟数(0 &ndash; 59)</td> </tr> <tr> <td>mm</td> <td>含前导零的分钟数(00 &ndash; 59)</td> </tr> <tr> <td>s</td> <td>不含前导零的秒数(0 &ndash; 59)</td> </tr> <tr> <td>ss</td> <td>含前导零的秒数(00 &ndash; 59)</td> </tr> <tr> <td>t</td> <td>单字符时间标记, 例如 A 或 P(取决于区域设置)</td> </tr> <tr> <td>tt</td> <td>多字符时间标记, 例如 AM 或 PM(取决于区域设置)</td> </tr> </table> <h2 id="Standalone_Formats">独立格式</h2> <p>下面的格式必须 <strong>单独</strong> 使用; 即在 <em>Format</em> 参数中不能含有其他格式或文本. 这些格式不区分大小写.</p> <table class="info"> <tr> <th style="width:15%">Format</th> <th abbr="Descr">描述</th> </tr> <tr> <td style="width:15%">(空)</td> <td>留空 <em>Format</em> 来生成时间后跟着长日期. 例如, 在某些区域设置中它可能看起来像这样 4:55 PM Saturday, November 27, 2004(译者注: 显示的内容与顺序与系统设置有关, 中文: 下午 4:55 星期六,2004年11月27日)</td> </tr> <tr> <td>Time</td> <td>当前用户区域设置的时间表示, 例如 5:26 PM(译者注: 显示的内容与顺序与系统设置有关, 中文: 下午 5:26)</td> </tr> <tr> <td>ShortDate</td> <td>当前用户区域设置的短日期表示, 例如 02/29/04(译者注: 显示的内容与顺序与系统设置有关, 中文: 2004/2/29 )</td> </tr> <tr> <td>LongDate</td> <td>当前用户区域设置的长日期表示, 例如 Friday, April 23, 2004(译者注: 显示的内容与顺序与系统设置有关, 中文: 星期五,2004年4月23日)</td> </tr> <tr> <td>YearMonth</td> <td>当前用户区域设置的年份和月份格式, 例如 February, 2004(译者注: 显示的内容与顺序与系统设置有关, 中文: 2004年2月)</td> </tr> <tr> <td>YDay</td> <td>不含前导零的年份的天数(1 &ndash; 366)</td> </tr> <tr> <td>YDay0</td> <td>含前导零的年份的天数(001 &ndash; 366)</td> </tr> <tr> <td>WDay</td> <td>星期的天数(1 &ndash; 7). 星期天为 1.</td> </tr> <tr> <td>YWeek</td> <td>ISO 8601 中规定的完全年份和周数. 例如: 200453. 如果含有 1 月 1 日的星期有四天以上在新年里, 则它被认为是新年的第一星期. 否则, 它为前一年的最后一个星期, 而下一星期为新年的第一星期. 因此, 1 月 4 日和首个星期四总是在第一周.</td> </tr> </table> <h2 id="Additional_Options">附加选项</h2> <p>下列选项可以紧跟在 <em>YYYYMMDDHH24MISS</em> 时间戳后(如果没有时间戳, 它们也可以单独使用). 在下面的例子中, 请注意最后的四项间没有逗号:</p> <pre>OutputVar := FormatTime("20040228 LSys D1 D4")</pre> <p><strong>R</strong>: 反转. 让日期在时间之前(仅当 <em>Format</em> 为空时才有意义).</p> <p><strong>Ln</strong>: 如果此选项 <em>不</em> 存在, 则使用当前用户区域设置来格式化字符串. 要使用系统的区域设置, 请指定 LSys. 要使用特殊的区域设置, 请指定字母 L 后面跟着十六进制或十进制的区域设置标识符(LCID). 关于如何构建 LCID 的信息, 请在 <a href="https://www.microsoft.com">www.microsoft.com</a> 上搜索下列短语: Locale Identifiers</p> <p><strong>Dn</strong>: 日期选项. 请指定 <strong>n</strong> 为下列数字的其中一个:</p> <ul> <li>0 = 强制使用默认选项. 这也会让短日期生效.</li> <li>1 = 使用短日期(仅当 <em>Format</em> 为空时才有意义; 与 2 和 8 不兼容).</li> <li>2 = 使用长日期(仅当 <em>Format</em> 为空时才有意义; 与 1 和 8 不兼容).</li> <li>4 = 使用备用日历(如果有).</li> <li>8 = 使用年份-月份格式(仅当 <em>Format</em> 为空时才有意义; 与 1 和 2 不兼容).</li> <li>0x10 = 为从左到右的阅读顺序布局添加标记.</li> <li>0x20 = 为从右到左的阅读顺序布局添加标记.</li> <li>0x80000000 = 不遵循任何用户对系统默认日期格式的覆盖.</li> <li>0x40000000 = 使用系统 ANSI 代码页而不是区域设置代码页进行字符串转换.</li> </ul> <p><strong>Tn</strong>: 时间选项. 请指定 <strong>n</strong> 为下列数字的其中一个:</p> <ul> <li>0 = 强制使用默认选项. 这也使得会显示分钟数和秒数.</li> <li>1 = 省略分钟数和秒数.</li> <li>2 = 省略秒数.</li> <li>4 = 省略时间标记(例如 AM/PM).</li> <li>8 = 始终使用二十四小时制而不是十二小时制.</li> <li>12 = 上面两个参数的组合.</li> <li>0x80000000 = 不遵循任何用户对系统默认日期格式的覆盖.</li> <li>0x40000000 = 使用系统 ANSI 代码页而不是区域设置代码页进行字符串转换.</li> </ul> <p class="note"><strong>注意</strong>: Dn 和 Tn 可以使用多次以使多个选项生效, 例如: <code>FormatTime("20040228 D2 D4 T1 T8")</code></p> <h2 id="Remarks">备注</h2> <p>您希望从 <em>Format</em>原义转换到最终字符串中的字母和数字应该用单引号括起来, 如此例所示: <code>"'Date:' MM/dd/yy 'Time:' hh:mm:ss tt"</code>.</p> <p>相反, 非字母数字字符(例如空格, tab, 换行符(`n), 斜杠, 冒号, 逗号和其他标点) 不需要包围在单引号中. 例外情况是单引号字符本身: 要产生原义的单引号, 请使用四个连续的单引号(''''), 不过如果它们已经包含在一对外部引号中则仅使用连续的两个就行了.</p> <p>如果 <em>Format</em> 同时包含日期和时间元素, 则它们不能混用. 换句话说, 这个字符串应该分成两半: 一半时间, 一半日期. 例如, 包含 "hh yyyy mm" 的格式字符串不会产生期望的结果, 因为它在两个时间元素间包含日期元素.</p> <p>当 <em>Format</em> 包含数值的天数(d 或 dd) 后跟着月份的全称(MMMM), 则使用月份名称的所有格形式(如果当前语言有所有格形式).</p> <p>相关提示, 可以使用 <a href="DateAdd.htm">DateAdd</a> 和 <a href="DateDiff.htm">DateDiff</a> 对日期和时间进行加减和比较.</p> <h2 id="Related">相关</h2> <p>要进行反向的转换 -- 即, <em>从</em> 格式化的日期/时间 <em>转换到</em> <a href="FileSetTime.htm#YYYYMMDD">YYYYMMDDHH24MISS</a> 格式 -- 请参阅 <a href="https://www.autohotkey.com/forum/topic20405.html">www.autohotkey.com/forum/topic20405.html</a></p> <p>另请参阅: <a href="GuiControls.htm#DateTime">Gui DateTime 控件</a>, <a href="Format.htm">Format</a>, <a href="../Variables.htm#date">内置的日期和时间变量</a>, <a href="FileGetTime.htm">FileGetTime</a></p> <h2 id="Examples">示例</h2> <div class="ex" id="ExBasic"> <p><a class="ex_number" href="#ExBasic"></a> 演示不同的用法.</p> <pre>TimeString := FormatTime() MsgBox "The current time and date (time first) is " TimeString TimeString := FormatTime("R") MsgBox "The current time and date (date first) is " TimeString TimeString := FormatTime(, "Time") MsgBox "The current time is " TimeString TimeString := FormatTime("T12", "Time") MsgBox "The current 24-hour time is " TimeString TimeString := FormatTime(, "LongDate") MsgBox "The current date (long format) is " TimeString TimeString := FormatTime(20050423220133, "dddd MMMM d, yyyy hh:mm:ss tt") MsgBox "The specified date and time, when formatted, is " TimeString MsgBox FormatTime(200504, "'Month Name': MMMM`n'Day Name': dddd") YearWeek := FormatTime(20050101, "YWeek") MsgBox "January 1st of 2005 is in the following ISO year and week number: " YearWeek</pre> </div> <div class="ex" id="ExFileTime"> <p><a class="ex_number" href="#ExFileTime"></a> 改变文件的日期-时间戳.</p> <pre>FileName := FileSelect(3,, "Pick a file") if FileName = "" <em>; 用户没有选取文件.</em> return FileTime := FileGetTime(FileName) FileTime := FormatTime(FileTime) <em>; 由于省略了最后一个参数, 所以获取长日期和时间.</em> MsgBox "The selected file was last modified at " FileTime</pre> </div> <div class="ex" id="ExFormatSec"> <p><a class="ex_number" href="#ExFormatSec"></a> 把指定的秒数转换成相应的小时数, 分钟数和秒数(hh:mm:ss 格式).</p> <pre>MsgBox FormatSeconds(7384) <em>; 7384 = 2 小时 + 3 分钟 + 4 秒. 它的结果: 2:03:04</em> FormatSeconds(NumberOfSeconds) <em>; 把指定的秒数转换成 hh:mm:ss 格式.</em> { time := 19990101 <em>; 任意日期的 *午夜*.</em> time := DateAdd(time, NumberOfSeconds, "Seconds") return NumberOfSeconds//3600 ":" FormatTime(time, "mm:ss") <em>/* ; 和上面方法不同的是, 这里不支持超过 24 小时的秒数: return FormatTime(time, "h:mm:ss") */</em> }</pre> </div> </body> </html>