Anpassade numeriska formatsträngar
Du kan skapa en anpassad numerisk formatsträng, som består av en eller flera anpassade numeriska specificerare, för att definiera hur numeriska data ska formateras. En anpassad numerisk formatsträng är alla formatsträngar som inte är en standardsträng i numeriskt format.
I följande tabell beskrivs de anpassade numeriska formatspecificerarna och exempelutdata som produceras av varje formatspecificerare. Gå till avsnittet Anteckningar för ytterligare information om hur du använder anpassade numeriska formatsträngar och avsnittet Exempel för en omfattande bild av deras användning.
Formatspecificerare | Name | beskrivning | Exempel |
---|---|---|---|
"0" | Platshållare utan plats | Ersätter noll med motsvarande siffra om en finns. annars visas noll i resultatsträngen. Mer information: Den anpassade specificeraren "0". |
1234.5678 ("00000") -> 01235 0.45678 ("0.00", en-US) -> 0.46 0,45678 ("0,00", fr-FR) -> 0,46 |
"#" | Platshållare för siffror | Ersätter symbolen "#" med motsvarande siffra om en finns. annars visas ingen siffra i resultatsträngen. Ingen siffra visas i resultatsträngen om motsvarande siffra i indatasträngen är en icke-signifikant 0. Till exempel 0003 ("#####") -> 3. Mer information: Den anpassade "#"-specificeraren. |
1234.5678 ("#####") -> 1235 0.45678 ("#.##", en-US) –> .46 0.45678 ("#.##", fr-FR) -> ,46 |
"." | Decimalkomma | Avgör platsen för decimalavgränsaren i resultatsträngen. Mer information: "". Anpassad specificerare. |
0.45678 ("0.00", en-US) -> 0.46 0,45678 ("0,00", fr-FR) -> 0,46 |
"," | Gruppavgränsare och nummerskalning | Fungerar som både en gruppavgränsare och en sifferskalningsspecificerare. Som gruppavgränsare infogar den ett lokaliserat gruppavgränsartecken mellan varje grupp. Som talskalningsspecificerare delar den upp ett tal med 1 000 för varje angivet kommatecken. Mer information: "," Anpassad specificerare. |
Gruppavgränsarespecificerare: 2147483647 ("##,#", en-US) –> 2 147 483 647 2147483647 ("##,#", es-ES) –> 2.147.483.647 Skalningsspecificerare: 2147483647 ("#,#,,", en-US) -> 2 147 2147483647 ("#,#,,", es-ES) -> 2.147 |
"%" | Platshållare i procent | Multiplicerar ett tal med 100 och infogar en lokaliserad procentsymbol i resultatsträngen. Mer information: Den anpassade specificeraren %. |
0.3697 ("%#0.00", en-US) –> %36.97 0.3697 ("%#0.00", el-GR) -> %36,97 0.3697 ("##.0 %", en-US) –> 37,0 % 0.3697 ("##.0 %", el-GR) -> 37,0 % |
"‰" | Platshållare per mille | Multiplicerar ett tal med 1 000 och infogar en lokaliserad symbol per mille i resultatsträngen. Mer information: Anpassad specificerare för "‰". |
0.03697 ("#0.00‰", en-US) -> 36.97‰ 0.03697 ("#0.00‰", ru-RU) -> 36,97‰ |
"E0" "E+0" "E-0" "e0" "e+0" "e-0" |
Exponentiell notation | Om det följs av minst 0 (noll) formateras resultatet med exponentiell notation. Fallet "E" eller "e" anger fallet med exponentsymbolen i resultatsträngen. Antalet nollor efter tecknet "E" eller "e" avgör det minsta antalet siffror i exponenten. Ett plustecken (+) anger att ett teckentecken alltid föregår exponenten. Ett minustecken (-) anger att ett teckentecken endast föregår negativa exponenter. Mer information: Anpassade specificerare för "E" och "e". |
987654 ("#0.0e0") –> 98.8e4 1503.92311 ("0.0##e+00") -> 1.504e+03 1.8901385E-16 ("0.0e+00") -> 1.9e-16 |
"\", "''", """" | Escape-tecken | Gör att nästa tecken eller tecken tolkas som en literal snarare än som en anpassad formatspecificerare. Mer information: Escape-tecken. |
987654 ("\###00\#") –> #987654# 987654 ("'#'##00'#'") –> #987654# 987654 ("""#""##00""#"")) –> #987654# |
"sträng" "sträng" |
Literal sträng avgränsare | Anger att de omslutna tecknen ska kopieras till resultatsträngen oförändrade. Mer information: Teckenliteraler. |
68 ("# 'grader'") -> 68 grader 68 ("#' grader'") -> 68 grader |
; | Avsnittsavgränsare | Definierar avsnitt med separata formatsträngar för positiva, negativa och noll tal. Mer information: ";" Avsnittsavgränsare. |
12.345 ("#0.0#;( #0.0#);-\0-") -> 12.35 0 ("#0.0#;( #0.0#);-\0-") -> -0- -12.345 ("#0.0#;( #0.0#);-\0-") -> (12.35) 12.345 ("#0.0#;( #0.0#)") -> 12.35 0 ("#0.0#;( #0.0#)") –> 0.0 -12.345 ("#0.0#;( #0.0#)") -> (12.35) |
Övrigt | Alla andra tecken | Tecknet kopieras till resultatsträngen oförändrad. Mer information: Teckenliteraler. |
68 ("# °") -> 68 ° |
Följande avsnitt innehåller detaljerad information om var och en av de anpassade numeriska formatspecificerarna.
Den anpassade specificeraren "0"
Den anpassade formatspecificeraren "0" fungerar som en nollplatshållare. Om värdet som formateras har en siffra i den position där noll visas i formatsträngen kopieras den siffran till resultatsträngen. annars visas en nolla i resultatsträngen. Positionen för den vänstra nollan före decimaltecknet och den högra nollan efter decimaltecknet avgör det intervall med siffror som alltid finns i resultatsträngen.
"00"-specificeraren gör att värdet avrundas till närmaste siffra före decimaltecknet, där avrundning bort från noll alltid används. Till exempel skulle formatering 34.5 med "00" resultera i värdet 35.
I följande exempel visas flera värden som formateras med hjälp av anpassade formatsträngar som innehåller noll platshållare.
let
Source =
{
Number.ToText(123, "00000", ""),
// Displays 00123
Number.ToText(1.2, "0.00", ""),
// Displays 1.20
Number.ToText(1.2, "00.00", ""),
// Displays 01.20
Number.ToText(1.2, "00.00", "da-DK"),
// Displays 01,20
Number.ToText(.56, "0.0", ""),
// Displays 0.6
Number.ToText(1234567890, "0,0", ""),
// Displays 1,234,567,890
Number.ToText(1234567890, "0,0", "el-GR"),
// Displays 1.234.567.890
Number.ToText(1234567890.123456, "0,0.0", ""),
// Displays 1,234,567,890.1
Number.ToText(1234.567890, "0,0.00", "")
// Displays 1,234.57
}
in
Source
Kommentar
Det tomma textvärdet ("") i den sista parametern för Number.ToText i föregående exempel refererar till den invarianta kulturen.
Den anpassade "#"-specificeraren
Den anpassade formatspecificeraren "#" fungerar som en sifferplatshållarsymbol. Om värdet som formateras har en siffra i den position där "#"-symbolen visas i formatsträngen kopieras den siffran till resultatsträngen. Annars lagras ingenting i den positionen i resultatsträngen.
Observera att den här specificeraren aldrig visar en nolla som inte är en signifikant siffra, även om noll är den enda siffran i strängen. Den visar endast noll om det är en betydande siffra i talet som visas.
Formatsträngen "##" gör att värdet avrundas till närmaste siffra före decimaltecknet, där avrundning bort från noll alltid används. Till exempel skulle formatering 34.5 med "##" resultera i värdet 35.
I följande exempel visas flera värden som formateras med hjälp av anpassade formatsträngar som innehåller platshållare för siffror.
let
Source =
{
Number.ToText(1.2, "#.##", ""),
// Displays 1.2
Number.ToText(123, "#####"),
// Displays 123
Number.ToText(123456, "[##-##-##]"),
// Displays [12-34-56]
Number.ToText(1234567890, "#"),
// Displays 1234567890
Number.ToText(1234567890, "(###) ###-####")
// Displays (123) 456-7890
}
in
Source
Om du vill returnera en resultatsträng där frånvarande siffror eller inledande nollor ersätts av blanksteg använder du Text.PadStart och anger en fältbredd, vilket visas i följande exempel.
let
Source = Text.Format("The value is: '#{0}'", {Text.PadStart(Number.ToText(.324, "#.###"), 5)})
in
Source
// The example displays the following output if the current culture
// is en-US:
// The value is: ' .324'
Den anpassade specificeraren "."
Den anpassade formatspecificeraren "." infogar en lokaliserad decimalavgränsare i resultatsträngen. Den första perioden i formatsträngen avgör platsen för decimaltecknet i det formaterade värdet. eventuella ytterligare perioder ignoreras. Om formatspecificeraren slutar med ett "." formateras endast de signifikanta siffrorna i resultatsträngen.
Tecknet som används som decimalavgränsare i resultatsträngen är inte alltid en punkt. det bestäms av den kultur som styr formateringen.
I följande exempel används formatspecificeraren "." för att definiera platsen för decimaltecknet i flera resultatsträngar.
let
Source =
{
Number.ToText(1.2, "0.00", ""),
// Displays 1.20
Number.ToText(1.2, "00.00", ""),
// Displays 01.20
Number.ToText(1.2, "00.00", "da-DK"),
// Displays 01,20
Number.ToText(.086, "#0.##%", ""),
// Displays 8.6%
Number.ToText(Double.From(86000), "0.###E+0", "")
// Displays 8.6E+4
}
in
Source
Den "," anpassade specificeraren
Tecknet "," fungerar som både en gruppavgränsare och en sifferskalningsspecificerare.
Gruppavgränsare: Om ett eller flera kommatecken anges mellan två sifferplatshållare (0 eller #) som formaterar de integralsiffror i ett tal infogas ett gruppavgränsartecken mellan varje nummergrupp i den integrerade delen av utdata.
Kulturen avgör vilket tecken som används som nummergruppsavgränsare och storleken på varje nummergrupp. Om till exempel strängen "#,#" och den invarianta kulturen används för att formatera talet 1000 är utdata "1 000".
Talskalningsspecificerare: Om ett eller flera kommatecken anges omedelbart till vänster om den explicita eller implicita decimalpunkten delas talet som ska formateras med 1 000 för varje kommatecken. Om strängen "0"till exempel används för att formatera talet 100 miljoner är utdata "100".
Du kan använda gruppavgränsare och nummerskalningsspecificerare i samma formatsträng. Om strängen "#,0" och den invarianta kulturen till exempel används för att formatera talet en miljard är utdata "1 000".
I följande exempel visas hur kommatecken används som gruppavgränsare.
let
Source =
{
Number.ToText(1234567890, "#,#", ""),
// Displays 1,234,567,890
Number.ToText(1234567890, "#,##0,,", "")
// Displays, 1,235
}
in
Source
I följande exempel visas hur kommatecknet används som en specificerare för talskalning.
let
Source =
{
Number.ToText(1234567890, "#,,", ""),
// Displays 1235
Number.ToText(1234567890, "#,,,", ""),
// Displays 1
Number.ToText(1234567890, "#,##0,,", "")
// Displays 1,235
}
in
Source
Den anpassade "%"-specificeraren
Ett procenttecken (%) i en formatsträng gör att ett tal multipliceras med 100 innan det formateras. Symbolen för lokaliserad procent infogas i talet på den plats där % visas i formatsträngen. Procenttecknet som används definieras av kulturen.
I följande exempel definieras en anpassad formatsträng som innehåller den anpassade specificeraren %.
let
Source = Number.ToText(.086, "#0.##%", "")
// Displays 8.6%
in
Source
Den anpassade specificeraren "‰"
Ett tecken per mille (‰ eller \u2030) i en formatsträng gör att ett tal multipliceras med 1 000 innan det formateras. Lämplig symbol per mille infogas i den returnerade strängen på den plats där symbolen ‰ visas i formatsträngen. Det per mille-tecken som används definieras av kulturen, som tillhandahåller kulturspecifik formateringsinformation.
I följande exempel definieras en anpassad formatsträng som innehåller den anpassade specificeraren "‰".
let
Source = Number.ToText(.00354, "#0.##" & Character.FromNumber(0x2030), "")
// Displays 3.54‰
in
Source
Anpassade specificerare för "E" och "e"
Om någon av strängarna "E", "E+", "E-", "e", "e+" eller "e-" finns i formatsträngen och följs omedelbart av minst en nolla formateras talet med hjälp av vetenskaplig notation med ett "E" eller "e" infogat mellan talet och exponenten. Antalet nollor som följer den vetenskapliga notationsindikatorn avgör det minsta antalet siffror som ska matas ut för exponenten. Formaten "E+" och "e+" anger att ett plustecken eller minustecken alltid ska föregå exponenten. Formaten "E", "E-", "e" eller "e-" anger att ett teckentecken endast ska föregå negativa exponenter.
I följande exempel formateras flera numeriska värden med hjälp av specificerarna för vetenskaplig notation.
let
Source =
{
Number.ToText(86000, "0.###E+0", ""),
// Displays 8.6E+4
Number.ToText(86000, "0.###E+000", ""),
// Displays 8.6E+004
Number.ToText(86000, "0.###E-000", "")
// Displays 8.6E004
}
in
Source
Escape-tecken
Symbolerna "#", "0", ".", ",", "%" och "‰" i en formatsträng tolkas som formatspecificerare snarare än som literaltecken. Beroende på deras position i en anpassad formatsträng kan även versaler och gemener "E" samt symbolerna + och - tolkas som formatspecificerare.
Om du vill förhindra att ett tecken tolkas som en formatspecificerare kan du:
- Föregå med ett omvänt snedstreck.
- Omge den med ett enda citattecken.
- Omge den med två dubbla citattecken.
Vart och ett av dessa tecken fungerar som escape-tecken. Escape-tecknet betyder att följande tecken är en teckenliteral som ska inkluderas i resultatsträngen oförändrad.
Om du vill inkludera ett omvänt snedstreck i en resultatsträng måste du undvika det med ett annat omvänt snedstreck (\\
).
Om du vill inkludera ett enda citattecken i en resultatsträng måste du undvika det med ett omvänt snedstreck (\'
). Om ett annat enda citattecken som inte är undantaget föregår det undantagna enkla citattecken, visas omvänt snedstreck i stället ('\'
visar \
).
Om du vill inkludera ett dubbelt citattecken i en resultatsträng måste du undvika två av dem med ett omvänt snedstreck (\""
).
I följande exempel används escape-tecken för att förhindra att formateringsåtgärden tolkar tecknen "#", "0" och "" som escape-tecken eller formatspecificerare.
let
Source =
{
Number.ToText(123, "\#\#\# ##0 dollars and \0\0 cents \#\#\#"),
// Displays ### 123 dollars and 00 cents ###
Number.ToText(123, "'###' ##0 dollars and '00' cents '###'"),
// Displays ### 123 dollars and 00 cents ###
Number.ToText(123, """###"" ##0 dollars and ""00"" cents ""###"""),
// Displays ### 123 dollars and 00 cents ###
Number.ToText(123, "\\\\\\ ##0 dollars and \0\0 cents \\\\\\"),
// Displays \\\ 123 dollars and 00 cents \\\
Number.ToText(123, "'\\\' ##0 dollars and '00' cents '\\\'"),
// Displays \\\ 123 dollars and 00 cents \\\
Number.ToText(123, """\\\"" ##0 dollars and ""00"" cents ""\\\""")
// Displays \\\ 123 dollars and 00 cents \\\
}
in
Source
Avsnittsavgränsaren ";"
Semikolonet (;) är en villkorsstyrd formatspecificerare som tillämpar olika formatering på ett tal beroende på om dess värde är positivt, negativt eller noll. För att skapa det här beteendet kan en anpassad formatsträng innehålla upp till tre avsnitt avgränsade med semikolon. De här avsnitten beskrivs i följande tabell.
Antal avsnitt | beskrivning |
---|---|
Ett avsnitt | Formatsträngen gäller för alla värden. |
Två avsnitt | Det första avsnittet gäller positiva värden och nollor, och det andra avsnittet gäller negativa värden. Om talet som ska formateras är negativt, men blir noll efter avrundning enligt formatet i det andra avsnittet, formateras den resulterande nolla enligt det första avsnittet. |
Tre avsnitt | Det första avsnittet gäller positiva värden, det andra avsnittet gäller negativa värden och det tredje avsnittet gäller nollor. Det andra avsnittet kan lämnas tomt (genom att inte ha något mellan semikolonen), i vilket fall det första avsnittet gäller för alla icke-nollvärden. Om talet som ska formateras inte är noll, men blir noll efter avrundning enligt formatet i det första eller andra avsnittet, formateras den resulterande nollan enligt det tredje avsnittet. |
Avsnittsavgränsare ignorerar all befintlig formatering som är associerad med ett tal när det slutliga värdet formateras. Negativa värden visas till exempel alltid utan minustecken när avsnittsavgränsare används. Om du vill att det slutliga formaterade värdet ska ha ett minustecken bör du uttryckligen inkludera minustecknet som en del av den anpassade formatspecificeraren.
I följande exempel används formatspecificeraren ";" för att formatera positiva, negativa och noll tal på olika sätt.
let
Source =
{
Number.ToText(1234, "##;(##)"),
// Displays 1234
Number.ToText(-1234, "##;(##)"),
// Displays (1234)
Number.ToText(0, "##;(##);**Zero**")
// Displays **Zero**
}
in
Source
Teckenliteraler
Formatspecificerare som visas i en anpassad numerisk formatsträng tolkas alltid som formateringstecken och aldrig som literaltecken. Detta omfattar följande tecken:
Alla andra tecken tolkas alltid som teckenliteraler och ingår i resultatsträngen oförändrad i en formateringsåtgärd. I en parsningsåtgärd måste de matcha tecknen i indatasträngen exakt. jämförelsen är skiftlägeskänslig.
I följande exempel visas en vanlig användning av literalteckenenheter (i det här fallet tusentals):
let
Source = Number.ToText(123.8, "#,##0.0K")
// Displays 123.8K
in
Source
Det finns två sätt att ange att tecken ska tolkas som literaltecken och inte som formateringstecken, så att de kan inkluderas i en resultatsträng eller parsas i en indatasträng:
Genom att undvika ett formateringstecken. Mer information finns i Escape-tecken.
Genom att omsluta hela literalsträngen i citattecken apostrofer.
I följande exempel används båda metoderna för att inkludera reserverade tecken i en anpassad numerisk formatsträng.
let
Source =
{
Number.ToText(9.3, "##.0\%"),
// Displays 9.3%
Number.ToText(9.3, "\'##\'"),
// Displays '9'
Number.ToText(9.3, "\\##\\"),
// Displays \9\
Number.ToText(9.3, "##.0'%'"),
// Displays 9.3%
Number.ToText(9.3, "'\'##'\'"),
// Displays \9\
Number.ToText(9.3, "##.0""%"""),
// Displays 9.3%
Number.ToText(9.3, "\""##\""")
// Displays "9"
}
in
Source
Kommentar
Flyttals-infinities och NaN
Oavsett formatsträngen, om värdet för en Decimal.Type
, Single.Type
eller Double.Type
flyttalstyp är positiv oändlighet, negativ oändlighet eller inte ett tal (NaN), är den formaterade strängen värdet för respektive Number.PositiveInfinity, Number.NegativeInfinityeller Number.NaN konstanter som anges av den aktuella kulturen.
Avrundnings- och fastpunktsformatsträngar
För formatsträngar med fast punkt (dvs. formatsträngar som inte innehåller tecken i vetenskapligt notationsformat) avrundas talen till så många decimaler som det finns sifferplatshållare till höger om decimaltecknet. Om formatsträngen inte innehåller en decimalpunkt avrundas talet till närmaste heltal. Om talet har fler siffror än det finns platshållare för siffror till vänster om decimaltecknet kopieras de extra siffrorna till resultatsträngen omedelbart före platshållaren för den första siffran.
Exempel
I följande exempel visas två anpassade numeriska formatsträngar. I båda fallen visar sifferplatshållaren (#
) numeriska data och alla andra tecken kopieras till resultatsträngen.
let
Source =
{
Number.ToText(1234567890, "(###) ###-####"),
// Displays (123) 456-7890
Number.ToText(42, "My Number = #")
// Displays My number = 42
}
in
Source