C#实现将浮点数表示的货币数量以汉字大写形式输出的方法

本文实例讲述了C#实现将浮点数表示的货币数量以汉字大写形式输出的方法。分享给大家供大家参考。具体如下:

1.函数代码

注:本段代码中能转化的最大的数为(1亿亿-0.01),如果要转化更大的浮点数,则需要做适当修改。

/// <summary>
/// 将字符型变量转化为大写汉语数字
/// </summary>
/// <param name="ch">字符 '0'~'9'</param>
/// <returns></returns>
private static string NumToChr(char ch)
{
 switch (ch)
 {
  case '0': return "零";
  case '1': return "壹";
  case '2': return "贰";
  case '3': return "叁";
  case '4': return "肆";
  case '5': return "伍";
  case '6': return "陆";
  case '7': return "柒";
  case '8': return "捌";
  case '9': return "玖";
  default: return "";
 }
}
/// <summary>
/// 把数字转换为大写数字
/// </summary>
/// <param name="n"></param>
/// <returns></returns>
private static string RMBToChr(double n)
{
 //保留小数点后两位数字
 string sMoney = n.ToString("#0.00");
 StringBuilder sbResult = new StringBuilder();
 for (int i = 0; i < sMoney.Length; i++)
 {
  //遇到小数点,则后面 A.XX 写为 A圆X角X分
  if (sMoney[i] == '.')
  {
   sbResult.Append("圆");
   //角和分属性都为0时直接写整字
   if (sMoney[i + 1] == '0' && sMoney[i + 2] == '0')
   {
    sbResult.Append("整");
    break;
   }
   else
   {
    //角和分属性只有在对应位不为0时才写
    if (sMoney[i + 1] != '0')
    {
     sbResult.Append(NumToChr(sMoney[i + 1]) + "角");
    }
    if (sMoney[i + 2] != '0')
    {
     sbResult.Append(NumToChr(sMoney[i + 2]) + "分");
    }
    else //分为0时也要写整字
    {
     sbResult.Append("整");
    }
    break;
   }
  }
  //非零数字直接输出对应数字和位
  if (sMoney[i] != '0')
  {
   sbResult.Append(NumToChr(sMoney[i]));
   //补上相应位的权
   int temp = sMoney.Length - 4 - i;
   switch (temp)
   {
    case 0: break;
    case 1: sbResult.Append("拾"); break;
    case 2: sbResult.Append("佰"); break;
    case 3: sbResult.Append("仟"); break;
    case 4: sbResult.Append("万"); break;
    case 5: sbResult.Append("拾"); break;
    case 6: sbResult.Append("佰"); break;
    case 7: sbResult.Append("仟"); break;
    case 8: sbResult.Append("亿"); break;
    case 9: sbResult.Append("拾"); break;
    case 10: sbResult.Append("百"); break;
    case 11: sbResult.Append("仟"); break;
    case 12: sbResult.Append("万"); break;
    default: throw new Exception("这个数太大了!");
   }
  }
  else //如果该位数字为0,则万位和亿位要写权,多个连续0就写一个零
  {
   int temp = sMoney.Length - 4 - i;
   if (temp == 4) { sbResult.Append("万"); continue; }
   else if (temp == 8) { sbResult.Append("亿"); continue; }
   else if (sMoney[i + 1] == '0') { continue; }
   else sbResult.Append("零");
  }
 }
 return sbResult.ToString();
}

2.Main函数调用

static void Main(string[] args)
{
 //数字转化为人民币大写
 Console.WriteLine(RMBToChr(12345));
 Console.WriteLine(RMBToChr(60001.215));
 Console.WriteLine(RMBToChr(70010001.8));
 Console.WriteLine(RMBToChr(10110901.01));
 Console.WriteLine(RMBToChr(0.01));
 Console.ReadLine();
}

3.运行示例

希望本文所述对大家的C#程序设计有所帮助。

(0)

相关推荐

  • 浅谈c# 浮点数计算

    给大家看个计算题,看看大家的算术能力. 0.1 +0.1 +0.1 - 0.3 等于几? 大家可能会说这么简单的问题,是不是看不起我?肯定等于0啊. 如果大家直接算的是没有问题的,但是如果用计算机呢? 见证奇迹的时刻到了,看代码: void Main() { var f = 0.1 +0.1 +0.1 -0.3; Console.WriteLine("f=={0}",f); } 运行结果: 这是因为计算机的精度的问题,在计算机的内部存储和运算的精度缺失等问题,我解释的可能不太明白,不过

  • C#浮点数的表示和基本运算

    1 浮点数的表示 通常,我们可以用下面的格式来表示浮点数 S P M 其中S是符号位,P是阶码,M是尾数 对于IBM-PC而言,单精度浮点数是32位(即4字节)的,双精度浮点数是64位(即8字节)的.两者的S,P,M所占的位数以及表示方法由下表可知 S P M 表示公式 偏移量 1 8 23 (-1)S*2(P-127)*1.M 127 1 11 52 (-1)S*2(P-1023)*1.M 1023 以单精度浮点数为例,可以得到其二进制的表示格式如下 S(第31位) P(30位到23位) M(

  • C#实现将浮点数表示的货币数量以汉字大写形式输出的方法

    本文实例讲述了C#实现将浮点数表示的货币数量以汉字大写形式输出的方法.分享给大家供大家参考.具体如下: 1.函数代码 注:本段代码中能转化的最大的数为(1亿亿-0.01),如果要转化更大的浮点数,则需要做适当修改. /// <summary> /// 将字符型变量转化为大写汉语数字 /// </summary> /// <param name="ch">字符 '0'~'9'</param> /// <returns></

  • go浮点数转字符串保留小数点后N位的完美解决方法

    最近在项目中碰到很多次float转string,同时要求保留小数点后几位,并且去掉小数点后0的场景 虽然问题很简单,但是隔了挺久没处理这种场景就有些生疏了,自己也搜了一下,很多回答都不太满意.这里贴一下自己的做法,如果有更好的解决办法的话,还请多多指教 // 主要逻辑就是先乘,trunc之后再除回去,就达到了保留N位小数的效果 func FormatFloat(num float64, decimal int) string { // 默认乘1 d := float64(1) if decima

  • PHP将页面中点击数量高的链接进行高亮显示的方法

    背景和需求 就好比说页面导航的左侧是分类,分类下面有很多链接.我现在想统计所有分类下面点击次数最多的一个,并把其颜色做特殊处理! 大致的数据结构如下: { "content": [ { "id": "1", "name": "htmldrive", "url": "http://www.htmldrive.net/", "cate": "

  • C 语言基础教程(我的C之旅开始了)[七]

    17. 基本数据类型:布尔型(_Bool type) _Bool 型是 C99 添加的,用于表示布尔值,亦即是表示逻辑真(true)和逻辑假(false).因为 C 用 1 表示 true ,0 表示 false ,所以 _Bool 实际上是整数类型.理论上 _Bool 只需要 1 bit 存储单元,因为1 bit 就足以表示 0 和 1 .事实上,_Bool 是无符号整型,一般占用 1 字节.例如: _Bool flag = 1; flag = 0; 包含标准头文件 stdbool.h 后,我

  • 浅谈Python的格式化输出

    python的输出 python输出中的print()函数,直接引用即可,它的完整格式为: #最后面还有文件操作的,我们主要学习输出相关,所以暂不加入 print(object, sep=' ', end='\n') object--是我们要输出的东西,可以是变量也可以是具体的数据,可以是单个也可以是多个,如果是多个中间用' , '分隔即可 sep--当我们要输出多个东西时才会用到,它表示我们输出的多个数据之间输出时用什么来进行分隔,如果输出时不设置,那就默认以一个空格来分隔 end--用来设置

  • SSH框架网上商城项目第28战之使用Ajax技术局部更新商品数量和总价

    之前,把项目部署了一下,玩了玩,今天完善了一下购物车中修改商品数量就能局部更新相应的总价的功能,大家都知道这得用Ajax实现,我之前也没学Ajax,刚好借助这个小功能,去简单学习一下Ajax的知识. 1. 问题的分析 先看一下页面中的情况: 功能如上,在没有Ajax之前,一般都是根据用户修改的值去找Action,然后返回新的jsp页面重新加载整个页面,完成数字的更新.但是有了Ajax技术后,我们可以利用Ajax技术局部刷新要改变的地方,而不是重新加载整个页面.首先看一下上图对应的jsp部分的代码

  • 妙用Ajax技术实现局部刷新商品数量和总价实例代码

    1. 问题的分析 先看一下页面中的情况: 功能如上,在没有Ajax之前,一般都是根据用户修改的值去找Action,然后返回新的jsp页面重新加载整个页面,完成数字的更新.但是有了Ajax技术后,我们可以利用Ajax技术局部刷新要改变的地方,而不是重新加载整个页面.首先看一下上图对应的jsp部分的代码: <div class="section_container"> <!-- 购物车 --> <div id="shopping_cart"

  • JavaScript解决浮点数计算不准确问题的方法分析

    本文实例讲述了JavaScript解决浮点数计算不准确问题的方法.分享给大家供大家参考,具体如下: 最近在学习electron框架,想利用这个框架做一个简单的计算器demo.当我对小数进行运算时,发现了一个问题. 0.1+0.2=? 输出结果是:0.30000000000000004. 为什么会这样呢? 其实对于浮点数的四则运算,几乎所有的编程语言都会有类似精度误差的问题,只不过在 C++/C#/Java 这些语言中已经封装好了方法来避免精度的问题,而 JavaScript 是一门弱类型的语言,

  • C++中double浮点数精度丢失的深入分析

    看了一篇关于C/C++浮点数的博文,在Win32下,把int, 指针地址,long等4字节整数赋给一个double后,再用该double数赋给原始类型的数,得到的结果于最初的数值一致,即不存在任何精度丢失.例如下面的结果将总是true: long a=123456; //assign any long number here double db=a; long b=db; printf("%s\n",a==b?"true":"false"); 但

  • C语言如何把浮点数转换为字符串

    目录 把浮点数转换为字符串 1.把float/double格式化输出到字符串 2.注意事项 整型.浮点型和字符串间转换 1.整型.浮点型-->字符串 2.字符串-->整型.浮点型 把浮点数转换为字符串 1.把float/double格式化输出到字符串 标准的C语言提供了atof函数把字符串转double,但是没有提供把float/double转换为字符串的库函数,而是采用sprintf和snprintf函数格式化输出到字符串. 函数声明: int sprintf(char *str, cons

随机推荐