直接调用即可

代码如下:

using System;
using System.Collections;
using System.Collections.Generic;
using System.Text;
using UnityEngine; public class ToolShu
{
/// <summary>
/// 阿拉伯数字转换中文汉字 数字大写
/// </summary>
public static string Rell(int input)
{
string ret = null;
int input2 = Math.Abs(input);
string resource = "零一二三四五六七八九";
string unit = "个十百千万亿兆京垓秭穰沟涧正载极";
if (input > Math.Pow(10, 4 * (unit.Length - unit.IndexOf('万'))))
{
throw new Exception("the input is too big,input:" + input);
}
Func<int, List<List<int>>> splitNumFunc = (val) => {
int i = 0;
int mod;
int val_ = val;
List<List<int>> splits = new List<List<int>>();
List<int> splitNums;
do
{
mod = val_ % 10;
val_ /= 10;
if (i % 4 == 0)
{
splitNums = new List<int>();
splitNums.Add(mod);
if (splits.Count == 0)
{
splits.Add(splitNums);
}
else
{
splits.Insert(0, splitNums);
}
}
else
{
splitNums = splits[0];
splitNums.Insert(0, mod);
}
i++;
} while (val_ > 0);
return splits;
};
Func<List<List<int>>, string> hommizationFunc = (data) => {
List<StringBuilder> builders = new List<StringBuilder>();
for (int i = 0; i < data.Count; i++)
{
List<int> data2 = data[i];
StringBuilder newVal = new StringBuilder();
for (int j = 0; j < data2.Count;)
{
if (data2[j] == 0)
{
int k = j + 1;
for (; k < data2.Count && data2[k] == 0; k++) ;
//个位不是0,前面补一个零
newVal.Append('零');
j = k;
}
else
{
newVal.Append(resource[data2[j]]).Append(unit[data2.Count - 1 - j]);
j++;
}
}
if (newVal[newVal.Length - 1] == '零' && newVal.Length > 1)
{
newVal.Remove(newVal.Length - 1, 1);
}
else if (newVal[newVal.Length - 1] == '个')
{
newVal.Remove(newVal.Length - 1, 1);
} if (i == 0 && newVal.Length > 1 && newVal[0] == '一' && newVal[1] == '十')
{//一十 --> 十
newVal.Remove(0, 1);
}
builders.Add(newVal);
}
StringBuilder sb = new StringBuilder();
for (int i = 0; i < builders.Count; i++)
{//拼接
if (builders.Count == 1)
{//个位数
sb.Append(builders[i]);
}
else
{
if (i == builders.Count - 1)
{//万位以下的
if (builders[i][builders[i].Length - 1] != '零')
{//十位以上的不拼接"零"
sb.Append(builders[i]);
}
}
else
{//万位以上的
if (builders[i][0] != '零')
{//零万零亿之类的不拼接
sb.Append(builders[i]).Append(unit[unit.IndexOf('千') + builders.Count - 1 - i]);
}
}
}
}
return sb.ToString();
};
List<List<int>> ret_split = splitNumFunc(input2);
ret = hommizationFunc(ret_split);
if (input < 0) ret = "-" + ret;
return ret;
}
/// <summary>
/// 转成钱好像也是可以的 阿拉伯数字转成中文大写
/// </summary>
/// <param name="input"></param>
/// <returns></returns>
public static string Rel(int input)
{
string ret = null;
int input2 = Math.Abs(input);
string resource = "零壹贰叁肆伍陆柒捌玖";
string unit = "个十百千万亿兆京垓秭穰沟涧正载极";
if (input > Math.Pow(10, 4 * (unit.Length - unit.IndexOf('万'))))
{
throw new Exception("the input is too big,input:" + input);
}
Func<int, List<List<int>>> splitNumFunc = (val) => {
int i = 0;
int mod;
int val_ = val;
List<List<int>> splits = new List<List<int>>();
List<int> splitNums;
do
{
mod = val_ % 10;
val_ /= 10;
if (i % 4 == 0)
{
splitNums = new List<int>();
splitNums.Add(mod);
if (splits.Count == 0)
{
splits.Add(splitNums);
}
else
{
splits.Insert(0, splitNums);
}
}
else
{
splitNums = splits[0];
splitNums.Insert(0, mod);
}
i++;
} while (val_ > 0);
return splits;
};
Func<List<List<int>>, string> hommizationFunc = (data) => {
List<StringBuilder> builders = new List<StringBuilder>();
for (int i = 0; i < data.Count; i++)
{
List<int> data2 = data[i];
StringBuilder newVal = new StringBuilder();
for (int j = 0; j < data2.Count;)
{
if (data2[j] == 0)
{
int k = j + 1;
for (; k < data2.Count && data2[k] == 0; k++) ;
//个位不是0,前面补一个零
newVal.Append('零');
j = k;
}
else
{
newVal.Append(resource[data2[j]]).Append(unit[data2.Count - 1 - j]);
j++;
}
}
if (newVal[newVal.Length - 1] == '零' && newVal.Length > 1)
{
newVal.Remove(newVal.Length - 1, 1);
}
else if (newVal[newVal.Length - 1] == '个')
{
newVal.Remove(newVal.Length - 1, 1);
} if (i == 0 && newVal.Length > 1 && newVal[0] == '一' && newVal[1] == '十')
{//一十 --> 十
newVal.Remove(0, 1);
}
builders.Add(newVal);
}
StringBuilder sb = new StringBuilder();
for (int i = 0; i < builders.Count; i++)
{//拼接
if (builders.Count == 1)
{//个位数
sb.Append(builders[i]);
}
else
{
if (i == builders.Count - 1)
{//万位以下的
if (builders[i][builders[i].Length - 1] != '零')
{//十位以上的不拼接"零"
sb.Append(builders[i]);
}
}
else
{//万位以上的
if (builders[i][0] != '零')
{//零万零亿之类的不拼接
sb.Append(builders[i]).Append(unit[unit.IndexOf('千') + builders.Count - 1 - i]);
}
}
}
}
return sb.ToString();
};
List<List<int>> ret_split = splitNumFunc(input2);
ret = hommizationFunc(ret_split);
if (input < 0) ret = "-" + ret;
return ret;
}
}

代码工具

具体用法:ToolShu.Rell(10086);

unity 阿拉伯数字转中文汉字的更多相关文章

  1. C# 阿拉伯数字转换为中文数字/中文数字转换为阿拉伯数字

    项目中经常会格式化数据,转换数字的使用情况比较多,记录一下数字转换的方法! 如果需要转换为繁体中文,将数组里的汉字换成繁体中文即可. 1.阿拉伯数字转换为中文数字 /// <summary> ...

  2. php使用strlen()判断中文汉字字符串长度

    php使用strlen()判断中文汉字字符串长度 对于含有中文情况,此时可以采用: iconv_strlen($str,"UTF-8"); iconv_strlen 是无论是何种编 ...

  3. Oracle一个中文汉字占用几个字节

    Oracle 一个中文汉字 占用几个字节,要根据Oracle中字符集编码决定   查看oracle server端字符集 select userenv('language') from dual; 如 ...

  4. char 型变量中能不能存贮一个中文汉字,为什么?

    char类型可以存储一个中文汉字,因为Java中使用的编码是Unicode(不选择任何特定的编码,直接使用字符在字符集中的编号,这是统一的唯一方法),一个char类型占2个字节(16比特),所以放一个 ...

  5. ASP.NET开发在JavaScript有中文汉字时出现乱码时简单有效的解决

    一般情况在使用ASP.NET开发使用JavaScript有中文汉字时不会出现乱码情况,比如:alert('您看到我了吗?');这样直接输入中文汉字的代码中是不会出现乱码的,如果出现了,一是检查Web. ...

  6. Oracle-一个中文汉字占几个字节?

    Oracle 一个中文汉字占用几个字节 Oracle 一个中文汉字 占用几个字节,要根据Oracle中字符集编码决定!!! 1. 如果定义为VARCHAR2(32 CHAR),那么该列最多就可以存储3 ...

  7. 用Python递归解决阿拉伯数字转为中文财务数字格式的问题(2)--打开思路的一种方法

    几天前自己写了个将阿拉伯数字转为中文财务数字的程序.用的递归,不幸的是它是树形递归. 虽然实际过程中不太可能出现金额数字大到让Python递归栈溢出,但是始终是一块心病,这玩意终究在理论上是受限制的. ...

  8. 【.net】在ASP.NET中,IE与Firefox下载文件名中带中文汉字的文件,文件名乱码的问题

    #问题:客户端为ie或Firefox,服务端为asp.net时,下载文件名中包含中文汉字时,下载下来的文件的文件名是乱码: #解决方案: 示例代码:下载名称中带汉字的文件: public void P ...

  9. uniGUI中Cookies使用中文汉字的方法(使用EncodeString函数编码)

    uniGUI中Cookies使用中文汉字的方法(使用EncodeString函数编码)   在目前的UniGUI(ver:0.88)中使用UniApplication.Cookies.SetCooki ...

  10. Javascript阿拉伯数字转中文

    Javascript阿拉伯数字转中文 template.helper('_toChinese', function (number) { /* * 单位 */ var units = '个十百千万@# ...

随机推荐

  1. Redis - 介绍与使用场景

    简介 Redis 的全称是 Remote Dictionary Server,是一个使用 C 语言编写的.开源的(BSD 许可)高性能非关系型(NoSQL)的键值对数据库. Redis 的数据是存储在 ...

  2. 反射概述-获取字节码Class对象的三种方式

    反射概述 判定结果∶*红色:失败*绿色:成功*一般我们会使用断言操作来处理结果*Assert.assertEquals(期望的结果,运算的结果);补充∶*Before:*修饰的方法会在测试方法之前被自 ...

  3. c++ 递推算法

    各位大佬不妨先点个赞再看文章! 递推法是一种重要的数学方法,在数学的各个领域中都有广泛的运用,也是计算机用于数值计算的一个重要算法.这种算法特点是:一个问题的求解需一系列的计算,在已知条件和所求问题之 ...

  4. 【Python】bytes和hex字符串之间的相互转换

    十六进制字符串:a="CC DD 01 61 F6 01 00 64 A4 81 00 00 00 8B" b=bytes.fromhex(a) 转为字节 from socket ...

  5. USACO 2023 January Contest, Bronze Problem 3. Moo Operations

    这道题目灰常简单,我们先从最简单的3个字符串开始 有以下几种情况: 可以看到,只有在中间是O的情况下才有可能变成MOO 辣么我们不妨在在s串中枚举这个中间 O 每枚举到一个就看看能不能用他的本身操作次 ...

  6. Maven配置 阿里云镜像地址

    <?xml version="1.0" encoding="UTF-8"?> <settings> <mirrors> &l ...

  7. Redis 源码解读之 expire 的时机

    Redis 源码解读之 expire 的时机 背景和问题 本文想解决的问题: redis 如何感知并触发 key 过期的? 如何防止大规模的 key 同时过期,导致 redis 主循环阻塞在清理过期 ...

  8. ctfshow_web入门 反序列化(254~266)

    要是没接触过的师傅们,可以先看看这个 web 254 这个题没有考什么,get方式传入payload即可,这里xxxxxx,就是6gex而已 payload: ?username=xxxxxx& ...

  9. Hbase一:Hbase介绍及特点

    转载请注明出处: 1.Google的三篇论文 2003年,Google发布Google File System论文,(GFS)这是一个可扩展的分布 式文件系统,用于大型的.分布式的.对大量数据进行访问 ...

  10. 免杀之:C# XOR Shellcode

    免杀之:C# XOR Shellcode 目录 免杀之:C# XOR Shellcode 1 环境准备 2 制作Shellcode后门文件 2.1 编译环境准备 2.2 生成XORKryptor程序 ...