在Excel中实现中文大写数字的方法

所属分类: 软件教程 / 办公软件 阅读数: 1877
收藏 0 赞 0 分享
一、自动更正法

  使用自动更正功能,可以简化用户对大写汉字的输入操作,例如可以将“1//”定义更正为“壹”,那么当要输入“壹”时,就可通过键入“1//”来实现。另外,这种定义以后不仅在Excel中有效,在Word中也同样有效,因为“自动更正”程序是Office组件所公用的。

  用“自动更正”是最简单易行的,用户可自由、方便地输入要写的大写读法。然而它的局限性也很明显,即它虽然给使用者提供了输入大写数字的方便手段,但终究还是需要人工输入,不能自动、实时地依当前的实际数字结果进行更新。


  二、工作表函数替换法

  要做到数值的自动更新,一般都会想到用VB构造函数法,但其实我们可采用一个简单的方法,即工作表函数的替换法。顾名思义,所谓“工作表函数的替换法”,就是将原来的结果换去一部分。那么换什么,又怎样换?

  我们知道,在Excel中,提供了多种数字的显示格式。其中文版实际上也包括数字的大写读法显示格式,但遗憾的是这个功能对一般用户来说基本上不能用,因为Microsoft在实现这个数字显示格式时犯了一个小小的错误,例如“33.56”这个数,它显示出来的是“叁拾叁.伍陆”。很显然,没有将小数点作有效处理。

  虽然这个显示格式是错的,但其劳动成果还是能为我们所用——只要能设法将其小数点作有效处理。做到这一点也并不难,可以先将数字以其内置的中文大写显示格式转变为文本格式,即使用TEXE( )函数将其结果转化为字符串,然后将小数点“.”用汉字“点”换掉(使用SUBSTITUTE( )函数。

  例如,若要将B1单元格内容重写为大写,则可以在单元格中输入如下公式:

复制代码
代码如下:

=SUBSTITUTE(TEXT(B1,"G/通用格式"),".","点")

使用这样一个小小的公式应当说并不复杂,不过,这样做仍不能满足某些情况下的要求,因为使用大写表示数额一般只应用于财会方面,其他很少这么用。在上例中,对数字“33.56”,往往要求结果写为“叁拾叁元伍角陆分”。那么,如何将“33.00”写为“叁拾叁元整”呢?

  实现这一功能的逻辑也不太复杂。我们可以看到,Excel显示格式的小数点前的数字读法是没有错的,可将其取出来作为一个字符串;小数点后面的数字则麻烦些,必取出来,再以低位是否都为“0”来判断是要写“整”还是“零”。还要将“元”、“角”、“分”等字串适当地插入,最后把几个字串连接起来就行了。我们仍将B1 单元格内容作格式转化,则具体实现如下:

复制代码
代码如下:

=TEXT(INT(B1),"G/通用格式")&"元"&IF((INT(B1*10)-INT(B1) *10)=0," ",TEXT(INT(B1*10) - INT (B1) * 10 ,"G/通用格式") &"角")&IF((INT(B1*100)-INT(B1*10) *10)=0,"整",TEXT (INT (B1*100) - INT ( B1*10) *10,"G/通用格式")&"分")

写这么一长串的公式看来似乎有些吓人,但是,如果在常要修改数据的表中或在模板里以这个方法实现大写汉字显示的话,则以后不但省事而且不易出错。


  三、VB编程法的思路

  可以用VB写一个函数,以后可像Excel的内部函数一样直接被调用,不过这需要熟悉VB编程。在编程过程中可用一般的方法调用VB函数,也可以借用我们前面所列“代换法”中的函数。但前面的公式中用的大多是Excel的工作表函数,在VB中不能直接使用,若非要用,也只能通过层次关系调用它(即用“Application WorksheetFunction”方式调用)。

  但个人认为最好自己用VB函数写,因为这样的话,较通用且可移植性好。若只用VB函数,具体方法与代换法也有类似之处,但小数点前的处理要复杂得多,相应的代码也太长。
更多精彩内容其他人还在看

excel表格中怎么使用数据画鸭子?

excel表格中怎么使用数据画鸭子?excel表格中想制作一个鸭子的图案,该怎么制作呢?今天我们就来看看excel表格中绘制鸭子的方法,很简单,需要的朋友可以参考下
收藏 0 赞 0 分享

PPT怎么制作利用对称轴计算的课件?

PPT怎么制作利用对称轴计算的课件?ppt中想制作一个正方形的表格来快速计算数字总和,下面我们就来看看怎么在ppt中做出这种效果,很简单,需要的朋友可以参考下
收藏 0 赞 0 分享

在word文档中怎么插入页码呢?

多数Word文档的第一页为封面,第二页为目录,接着为序言之类的,因此页码也就不是从第二页开始,那么在word文档中怎么插入页码呢?下面小编就为大家详细介绍一下,来看看吧
收藏 0 赞 0 分享

Word2010怎么提取局部的图像?

有的时候对图片进行处理,并不想要图片所有内容,只需要局部,该怎么做?用专业的图片处理工具,大多数人都还不会,其实Word2010就有这个功能,去掉图片的背景色。那么Word2010怎么提取局部的图像?下面小编就为大家详细介绍一下,来看看吧
收藏 0 赞 0 分享

用excel vba编程画一匹马

excel是专门用于各种数据的处理、统计分析和辅助决策操作,虽然在excel中只出现文字和数字很正常,但是难免会让人感觉到枯燥乏味,提不起兴趣,下面小编就为大家详细介绍一下用excel vba编程画一匹马方法,来看看吧
收藏 0 赞 0 分享

excel中行号和列标怎么打印出来?

在我们处理电子表格的时候,有时候我们需要将表格的行号和列号打印出来,那么应该如何设置呢?下面小编就为大家详细介绍一下,不会的朋友可以参考本文,来看看吧
收藏 0 赞 0 分享

excel背景如何设置?excel文件设置背景方法图解

Excel表格背景样式应用也开始普遍应用,有的表格不需要用图表的形式来显示,那么表格的美观就会更加引起重视,那么excel背景如何设置?下面小编就为大家详细介绍excel文件设置背景方法,来看看吧
收藏 0 赞 0 分享

word怎样设置段落格式?word段落格式设置介绍

对于文档中的段落文本内容,我们可以设置其段落格式,行距决定段落中各行文字之间的垂直距离,段落间距决定段落上方和下方的空间。那么word怎样设置段落格式?下面小编就为大家介绍word段落格式设置方法,来看看吧
收藏 0 赞 0 分享

Word2016怎么使用能够启格式跟踪功能?

Word2016怎么使用能够启格式跟踪功能?word中的跟踪功能就是跟踪用户对文字所做的格式设置,从而帮助我们在其他位置应用相同的格式。下面我们就来看看 word2016,
收藏 0 赞 0 分享

Word2016文档中怎么设置段落编号?

Word2016文档中怎么设置段落编号?Word2016文档中段落很多,为了让文件看起来整体有序,整齐美观,想给段落设置编号,该怎么设置呢?请看下文Word2016设置段落编号的教程,需要的朋友可以参考下
收藏 0 赞 0 分享
查看更多