c#:我不知道的格式转换

C#数值格式化指南

1. String.Format

 

 

C#格式化数值结果表

字符

说明

示例

输出

C货币string.Format("{0:C3}", 2)$2.000
D十进制string.Format("{0:D3}", 2)002
E科学计数法1.20E+0011.20E+001
G常规string.Format("{0:G}", 2)2
N用分号隔开的数字string.Format("{0:N}", 250000)250,000.00
X十六进制string.Format("{0:X000}", 12)C


string.Format("{0:000.000}", 12.2)012.200

字符

说明

示例

输出

C货币string.Format("{0:C3}", 2)$2.000
D十进制string.Format("{0:D3}", 2)002
E科学计数法1.20E+0011.20E+001
G常规string.Format("{0:G}", 2)2
N用分号隔开的数字string.Format("{0:N}", 250000)250,000.00
X十六进制string.Format("{0:X000}", 12)C


string.Format("{0:000.000}", 12.2)

Strings

There really isn't any formatting within a strong, beyond it's alignment. Alignment works for any argument being printed in a String.Format call.

 

 

SampleGenerates
String.Format("->{1,10}<-", "Hello");-> Hello<-
String.Format("->{1,-10}<-", "Hello");->Hello <-

 

Numbers

Basic number formatting specifiers:

 

 

SpecifierTypeFormat

Output
(Passed
Double 1.42)

Output
(Passed
Int -12400)

cCurrency{0:c}$1.42-$12,400
dDecimal (Whole number){0:d}System.
FormatException
-12400
eScientific{0:e}1.420000e+000-1.240000e+004
fFixed point{0:f}1.42-12400.00
gGeneral{0:g}1.42-12400
nNumber with commas for thousands{0:n}1.42-12,400
rRound trippable{0:r}1.42System.
FormatException
xHexadecimal{0:x4}System.
FormatException
cf90

 

Custom number formatting:

 

 

SpecifierTypeExample Output (Passed Double 1500.42)Note
0Zero placeholder{0:00.0000}1500.4200Pads with zeroes.
#Digit placeholder{0:(#).##}(1500).42 
.Decimal point{0:0.0}1500.4 
,Thousand separator{0:0,0}1,500Must be between two zeroes.
,.Number scaling{0:0,.} 2Comma adjacent to Period scales by 1000.
%Percent{0:0%}150042%Multiplies by 100, adds % sign.
eExponent placeholder{0:00e+0}15e+2Many exponent formats available.
;Group separatorsee below  

 

The group separator is especially useful for formatting currency values which require that negative values be enclosed in parentheses. This currency formatting example at the bottom of this document makes it obvious:

Dates

Note that date formatting is especially dependant on the system's regional settings; the example strings here are from my local locale.

 

 

SpecifierTypeExample (Passed System.DateTime.Now)
dShort date10/12/2002
DLong dateDecember 10, 2002
tShort time10:11 PM
TLong time10:11:29 PM
fFull date & time December 10, 2002 10:11 PM
FFull date & time (long)December 10, 2002 10:11:29 PM
gDefault date & time10/12/2002 10:11 PM
GDefault date & time (long)10/12/2002 10:11:29 PM
MMonth day patternDecember 10
rRFC1123 date stringTue, 10 Dec 2002 22:11:29 GMT
sSortable date string2002-12-10T22:11:29
uUniversal sortable, local time2002-12-10 22:13:50Z
UUniversal sortable, GMTDecember 11, 2002 3:13:50 AM
YYear month patternDecember, 2002

 

The 'U' specifier seems broken; that string certainly isn't sortable.

Custom date formatting:

 

 

SpecifierTypeExample Example Output
ddDay{0:dd}10
dddDay name{0:ddd}Tue
ddddFull day name{0:dddd}Tuesday
f, ff, ...Second fractions{0:fff}932
gg, ...Era{0:gg}A.D.
hh2 digit hour{0:hh}10
HH2 digit hour, 24hr format{0:HH}22
mmMinute 00-59{0:mm}38
MMMonth 01-12{0:MM}12
MMMMonth abbreviation{0:MMM}Dec
MMMMFull month name{0:MMMM}December
ssSeconds 00-59{0:ss}46
ttAM or PM{0:tt}PM
yyYear, 2 digits{0:yy}02
yyyyYear{0:yyyy}2002
zzTimezone offset, 2 digits{0:zz}-05
zzzFull timezone offset{0:zzz}-05:00
:Separator{0:hh:mm:ss}10:43:20
/Separator{0:dd/MM/yyyy}10/12/2002

 

Enumerations

 

 

SpecifierType
gDefault (Flag names if available, otherwise decimal)
fFlags always
dInteger always
xEight digit hex.

 

Some Useful Examples

String.Format("{0:$#,##0.00;($#,##0.00);Zero}", value);

<think>好的,用户想了解如何用C#将INI文件转换为UTF-8编码,并请求示例代码。首先,我需要确认用户的需求。他们可能有一个INI文件,当前编码是UTF-8,比如可能是GBK或者ASCII,现在需要将其转换为UTF-8格式。 首先,我需要考虑如何读取原始文件。C#中处理文件编码通常会用到StreamReader和StreamWriter。用户需要指定正确的原始编码,否则读取时可能会出现乱码。比如,如果原始文件是GBK,就需要在StreamReader中设置Encoding.GetEncoding("GBK")。如果用户确定原始编码,可能需要自动检测,但自动检测编码在C#中比较复杂,可能需要使用第三方库。但用户的问题中没有提到自动检测,所以假设用户知道原始编码。 接下来是写入UTF-8文件。StreamWriter默认使用UTF-8无BOM,但有些情况下可能需要包含BOM。根据引用[1],UTF-8和带BOM的UTF-8的区别在于是否有开头的EF BB BF三个字节。用户是否需要包含BOM?通常,.NET的Encoding.UTF8会包含BOM,而UTF8Encoding(false)则带。需要根据用户的实际需求决定,但示例代码中使用Encoding.UTF8可能更稳妥。 然后,处理INI文件的内容。可能需要注意某些INI格式的特殊字符,比如注释或者节名,但转换编码本身需要修改内容,只需要正确读写即可。因此,代码逻辑应该是读取所有文本,然后以UTF-8编码保存。 另外,用户提到的引用[3]中提到了在PHP中处理编码的问题,比如全局设置default_charset的影响。在C#中,需要修改全局设置,只需在读写时指定正确的编码即可,这样更安全,会影响其他部分。 所以,步骤大致是:读取原始文件(指定原始编码),然后写入新文件(使用UTF-8编码)。示例代码需要展示如何实现这一点。同时,需要提醒用户替换原始编码,比如将"OriginalEncoding"替换为实际的编码,如GBK、ASCII等。 可能的问题:如果原始文件有BOM,是否需要处理?在读取时,StreamReader会自动处理BOM,所以需要特别处理。写入时,使用Encoding.UTF8会包含BOM,如果需要,可以使用new UTF8Encoding(false)。 此外,异常处理也很重要,比如文件是否存在、读写权限等,但示例代码可能简化这些部分,重点展示核心逻辑。 最后,生成相关问题,比如如何处理同编码的转换、BOM的影响、批量转换等,帮助用户进一步了解相关主题。</think>### C#转换INI文件到UTF-8编码的实现步骤 1. **读取原始文件内容** 使用 `StreamReader` 指定原始编码读取INI文件内容。若确定原始编码,需通过 `Encoding.GetEncodings()` 尝试常见编码如GBK、ISO-8859-1等[^2]。 2. **写入UTF-8编码文件** 通过 `StreamWriter` 将内容以UTF-8编码写入新文件。根据需求选择是否包含BOM(字节顺序标记),默认 `Encoding.UTF8` 包含BOM,若需无BOM格式可用 `new UTF8Encoding(false)`[^1]。 ### 示例代码 ```csharp using System; using System.IO; using System.Text; public class IniFileConverter { public static void ConvertToUTF8(string inputPath, string outputPath) { // 读取原始文件(假设原始编码为GBK) string content; using (var reader = new StreamReader(inputPath, Encoding.GetEncoding("GBK"))) { content = reader.ReadToEnd(); } // 写入UTF-8编码文件(包含BOM) using (var writer = new StreamWriter(outputPath, false, Encoding.UTF8)) { writer.Write(content); } } } ``` ### 关键说明 - **原始编码适配**:若文件实际编码非GBK,需替换为 `Encoding.ASCII`、`Encoding.GetEncoding("ISO-8859-1")` 等 - **BOM处理**:若需生成无BOM的UTF-8文件,改用 `new UTF8Encoding(false)` - **错误处理**:可添加 `try-catch` 块处理文件存在或权限问题
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值