格式字符串语法,摘取自JDK6
格式字符串語法
產生格式化輸出的每個方法都需要格式字符串 和參數列表。格式字符串是一個 String,它可以包含固定文本以及一個或多個嵌入的格式說明符。請考慮以下示例:
Calendar c = ...;String s = String.format("Duke's Birthday: %1$tm %1$te,%1$tY", c); 此格式字符串是 format 方法的第一個參數。它包含三個格式說明符 " %1$tm"、" %1$te" 和 " %1$tY",它們指出應該如何處理參數以及在文本的什么地方插入它們。格式字符串的其余部分是包括 "Dukes Birthday: " 和其他任何空格或標點符號的固定文本。 參數列表由傳遞給位于格式字符串之后的方法的所有參數組成。在上述示例中,參數列表的大小為 1,由對象 Calendar c 組成。- 常規類型、字符類型和數值類型的格式說明符的語法如下: %[argument_index$][flags][width][.precision]conversion
可選的 argument_index 是一個十進制整數,用于表明參數在參數列表中的位置。第一個參數由 "1$" 引用,第二個參數由 "2$" 引用,依此類推。
可選 flags 是修改輸出格式的字符集。有效標志集取決于轉換類型。
可選 width 是一個非負十進制整數,表明要向輸出中寫入的最少字符數。
可選 precision 是一個非負十進制整數,通常用來限制字符數。特定行為取決于轉換類型。
所需 conversion 是一個表明應該如何格式化參數的字符。給定參數的有效轉換集取決于參數的數據類型。
- 用來表示日期和時間類型的格式說明符的語法如下: %[argument_index$][flags][width]conversion
可選的 argument_index、flags 和 width 的定義同上。
所需的 conversion 是一個由兩字符組成的序列。第一個字符是 't' 或 'T'。第二個字符表明所使用的格式。這些字符類似于但不完全等同于那些由 GNU date 和 POSIX strftime(3c) 定義的字符。
- 與參數不對應的格式說明符的語法如下: %[flags][width]conversion
可選 flags 和 width 的定義同上。
所需的 conversion 是一個表明要在輸出中所插內容的字符。
轉換
轉換可分為以下幾類:
下表總結了受支持的轉換。由大寫字符(如 'B'、'H'、'S'、'C'、'X'、'E'、'G'、'A' 和 'T')表示的轉換與由相應的小寫字符的轉換等同,根據流行的 Locale 規則將結果轉換為大寫形式除外。后者等同于 String.toUpperCase() 的以下調用
out.toUpperCase()| 'b', 'B' | 常規 | 如果參數 arg 為 null,則結果為 "false"。如果 arg 是一個 boolean 值或 Boolean,則結果為 String.valueOf() 返回的字符串。否則結果為 "true"。 |
| 'h', 'H' | 常規 | 如果參數 arg 為 null,則結果為 "null"。否則,結果為調用 Integer.toHexString(arg.hashCode()) 得到的結果。 |
| 's', 'S' | 常規 | 如果參數 arg 為 null,則結果為 "null"。如果 arg 實現 Formattable,則調用 arg.formatTo。否則,結果為調用 arg.toString() 得到的結果。 |
| 'c', 'C' | 字符 | 結果是一個 Unicode 字符 |
| 'd' | 整數 | 結果被格式化為十進制整數 |
| 'o' | 整數 | 結果被格式化為八進制整數 |
| 'x', 'X' | 整數 | 結果被格式化為十六進制整數 |
| 'e', 'E' | 浮點 | 結果被格式化為用計算機科學記數法表示的十進制數 |
| 'f' | 浮點 | 結果被格式化為十進制數 |
| 'g', 'G' | 浮點 | 根據精度和舍入運算后的值,使用計算機科學記數形式或十進制格式對結果進行格式化。 |
| 'a', 'A' | 浮點 | 結果被格式化為帶有效位數和指數的十六進制浮點數 |
| 't', 'T' | 日期/時間 | 日期和時間轉換字符的前綴。請參閱日期/時間轉換。 |
| '%' | 百分比 | 結果為字面值 '%' ('\u0025') |
| 'n' | 行分隔符 | 結果為特定于平臺的行分隔符 |
任何未明確定義為轉換的字符都是非法字符,并且都被保留,以供將來擴展使用。
日期/時間轉換
以下日期和時間轉換的后綴字符是為 't' 和 'T' 轉換定義的。這些類型相似于但不完全等同于那些由 GNU date 和 POSIX strftime(3c) 定義的類型。提供其他轉換類型是為了訪問特定于 Java 的功能(如將 'L' 用作秒中的毫秒)。
以下轉換字符用來格式化時間:
| 'H' | 24 小時制的小時,被格式化為必要時帶前導零的兩位數,即 00 - 23。 |
| 'I' | 12 小時制的小時,被格式化為必要時帶前導零的兩位數,即 01 - 12。 |
| 'k' | 24 小時制的小時,即 0 - 23。 |
| 'l' | 12 小時制的小時,即 1 - 12。 |
| 'M' | 小時中的分鐘,被格式化為必要時帶前導零的兩位數,即 00 - 59。 |
| 'S' | 分鐘中的秒,被格式化為必要時帶前導零的兩位數,即 00 - 60 ("60" 是支持閏秒所需的一個特殊值)。 |
| 'L' | 秒中的毫秒,被格式化為必要時帶前導零的三位數,即 000 - 999。 |
| 'N' | 秒中的毫微秒,被格式化為必要時帶前導零的九位數,即 000000000 - 999999999。 |
| 'p' | 特定于語言環境的 上午或下午 標記以小寫形式表示,例如 "am" 或 "pm"。使用轉換前綴 'T' 可以強行將此輸出轉換為大寫形式。 |
| 'z' | 相對于 GMT 的 RFC 822 格式的數字時區偏移量,例如 -0800。 |
| 'Z' | 表示時區縮寫形式的字符串。Formatter 的語言環境將取代參數的語言環境(如果有)。 |
| 's' | 自協調世界時 (UTC) 1970 年 1 月 1 日 00:00:00 至現在所經過的秒數,即 Long.MIN_VALUE/1000 與 Long.MAX_VALUE/1000 之間的差值。 |
| 'Q' | 自協調世界時 (UTC) 1970 年 1 月 1 日 00:00:00 至現在所經過的毫秒數,即 Long.MIN_VALUE 與 Long.MAX_VALUE 之間的差值。 |
以下轉換字符用來格式化日期:
| 'B' | 特定于語言環境的月份全稱,例如 "January" 和 "February"。 |
| 'b' | 特定于語言環境的月份簡稱,例如 "Jan" 和 "Feb"。 |
| 'h' | 與 'b' 相同。 |
| 'A' | 特定于語言環境的星期幾全稱,例如 "Sunday" 和 "Monday" |
| 'a' | 特定于語言環境的星期幾簡稱,例如 "Sun" 和 "Mon" |
| 'C' | 除以 100 的四位數表示的年份,被格式化為必要時帶前導零的兩位數,即 00 - 99 |
| 'Y' | 年份,被格式化為必要時帶前導零的四位數(至少),例如,0092 等于格里高利歷的 92 CE。 |
| 'y' | 年份的最后兩位數,被格式化為必要時帶前導零的兩位數,即 00 - 99。 |
| 'j' | 一年中的天數,被格式化為必要時帶前導零的三位數,例如,對于格里高利歷是 001 - 366。 |
| 'm' | 月份,被格式化為必要時帶前導零的兩位數,即 01 - 13。 |
| 'd' | 一個月中的天數,被格式化為必要時帶前導零兩位數,即 01 - 31 |
| 'e' | 一個月中的天數,被格式化為兩位數,即 1 - 31。 |
以下轉換字符用于格式化常見的日期/時間組合。
| 'R' | 24 小時制的時間,被格式化為 "%tH:%tM" |
| 'T' | 24 小時制的時間,被格式化為 "%tH:%tM:%tS"。 |
| 'r' | 12 小時制的時間,被格式化為 "%tI:%tM:%tS %Tp"。上午或下午標記 ('%Tp') 的位置可能與語言環境有關。 |
| 'D' | 日期,被格式化為 "%tm/%td/%ty"。 |
| 'F' | ISO 8601 格式的完整日期,被格式化為 "%tY-%tm-%td"。 |
| 'c' | 日期和時間,被格式化為 "%ta %tb %td %tT %tZ %tY",例如 "Sun Jul 20 16:17:00 EDT 1969"。 |
任何未明確定義為轉換的字符都是非法字符,并且都被保留,以供將來擴展使用。
標志
下表總結了受支持的標志。y 表示該標志受指示參數類型支持。
| '-' | y | y | y | y | y | 結果將是左對齊的。 |
| '#' | y1 | - | y3 | y | - | 結果應該使用依賴于轉換類型的替換形式 |
| '+' | - | - | y4 | y | - | 結果總是包括一個符號 |
| ' ' | - | - | y4 | y | - | 對于正值,結果中將包括一個前導空格 |
| '0' | - | - | y | y | - | 結果將用零來填充 |
| ',' | - | - | y2 | y5 | - | 結果將包括特定于語言環境的組分隔符 |
| '(' | - | - | y4 | y5 | - | 結果將是用圓括號括起來的負數 |
1 取決于 Formattable 的定義。
2 只適用于 'd' 轉換。
3 只適用于 'o'、'x' 和 'X' 轉換。
4 對 BigInteger 應用 'd'、'o'、'x' 和 'X' 轉換時,或者對 byte 及 Byte、short 及 Short、int 及 Integer、long 及 Long 分別應用 'd' 轉換時適用。
5 只適用于 'e'、'E'、'f'、'g' 和 'G' 轉換。
任何未顯式定義為標志的字符都是非法字符,并且都被保留,以供擴展使用。
寬度
寬度是將向輸出中寫入的最少字符數。對于行分隔符轉換,不適用寬度,如果提供寬度,則會拋出異常。
精度
對于常規參數類型,精度是將向輸出中寫入的最多字符數。
對于浮點轉換 'e'、'E' 和 'f',精度是小數點分隔符后的位數。如果轉換是 'g' 或 'G',那么精度是舍入計算后所得數值的所有位數。如果轉換是 'a' 或 'A',則不必指定精度。
對于字符、整數和日期/時間參數類型轉換,以及百分比和行分隔符轉換,精度是不適用的;如果提供精度,則會拋出異常。
參數索引
參數索引是一個十進制整數,用于表明參數在參數列表中的位置。第一個參數由 "1$" 引用,第二個參數由 "2$" 引用,依此類推。
根據位置引用參數的另一種方法是使用 '<' ('\u003c') 標志,這將會重用以前格式說明符的參數。例如,以下兩條語句產生的字符相同:
Calendar c = ...;String s1 = String.format("Duke's Birthday: %1$tm %1$te,%1$tY", c);String s2 = String.format("Duke's Birthday: %1$tm %<te,%<tY", c);總結
以上是生活随笔為你收集整理的格式字符串语法,摘取自JDK6的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 在Kmplayer中设置多字幕
- 下一篇: Java新鲜东西,带有标签的contin