C#中保留N位小数的几种方法(转)


C#中保留N位小数的几种方法(转)

1.只要求保留N位不四舍5入
   float f = 0.55555f;
           int i =(int)(f * 100);
          f = (float)(i*1.0)/100;//保留小数后2位

2.保留N位,四舍五入 
decimal d= decimal.Round(decimal.Parse("0.55555"),2);)//保留小数点后2位

3.保留N位四舍五入
Math.Round(0.55555,2)//保留小数点后2位

4,保留N位四舍五入
double dbdata = 0.55555;
string str1 =  dbdata.ToString("f2");//fN 保留N位,四舍五入

5.保留N位四舍五入
string result = String.Format("{0:N2}", 0.55555);//2位
string result = String.Format("{0:N3}", 0.55555);//3位

6.保留N位四舍五入
double s=0.55555;
result=s.ToString("#0.00");//点后面几个0就保留几位


  1. Console.WriteLine("{0:f4}",1.12345);  
  2.           
  3.             Console.ReadKey();//防止闪退  



            Double dValue = 95.12345;

            int iValue = 10000;
            string strValue = "95.12345";
            string result = "";

            result = Convert.ToDouble(dValue).ToString("0.00");//保留小数点后两位,结果为95.12
            result = Convert.ToDouble(iValue).ToString("0.00");//10000.00 
            result = Convert.ToDouble(strValue).ToString("0.00");//95.12

            result = Convert.ToDouble(dValue).ToString("P");//得到小数点后2位的百分比,自动 加上%号;//9512.35%
            result = Convert.ToDouble(strValue).ToString("f4");//保留小数点后4位;  //95.1235
            //要注意的一点是 Convert.ToDouble一定要是这种双精度的,不然会报错。





c#中的ROUND与java、sql的不同:


[csharp]  view plain  copy
  1. ROUND()是C#中math的一个成员函数.System.Math.Round(),这个函数有四种用法,  
[csharp]  view plain  copy
  1. 最长用的是对小数点位数的舍入.但这和现实生活中的“四舍五入”有一定区别,  
[csharp]  view plain  copy
  1. 也有别JAVA中Math.Round(),跟sql中的Math.Round()方法有别.  
  2. C#中Math.round()采用的是所谓“四舍六入五成双”的银行家舍入法---要舍得位  
[csharp]  view plain  copy
  1. 如果是5则舍入后末位要求是偶数,要舍得位如果不是五  则按四舍五入处理.  
  2.         如:  
  3.         Math.Round(1.2600,2);结果是1.26  
  4.         Math.Round(1.2460,2);结果是1.25  
  5.         Math.Round(1.2550,2);结果是1.25  
  6.         Math.Round(1.2551,2);结果是1.26  
  7.         Math.Round(1.2560,2);结果是1.26  

[csharp]  view plain  copy
  1. double s=0.55555;  
  2. result=s.ToString("#0.00");//点后面几个0就保留几位  
  3.   
  4. 如果要四舍五入的话,用这个  
  5. double dbdata = 0.55555;  
  6. string str1 = dbdata.ToString("f2");//fN 保留N位,四舍五入  



  • 4
    点赞
  • 34
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值