110,533
社区成员
发帖
与我相关
我的任务
分享
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
namespace WindowsFormsApplication2
{
public partial class Form1 : Form
{
string Zz = "零壹贰叁肆伍陆柒捌玖", Bj = "0123456789"; Double SsWr = new double(); bool PanDuan = true;
string[] Jz = { "元", "拾", "佰", "仟" };
string[] Jzs = { "拾", "佰", "仟" };
string[] Zs = { "万", "亿", "兆", "京", "垓", "秭", "穰", "沟", "涧", "正", "载", "极", "恒河沙", "阿僧祇", "那由他", "不可思议", "☆无量", "☆不可说☆" };
string[] Xs = { "角", "分", "厘","毫","丝","忽","微","纤","沙","尘","埃","渺","莫", "模糊", "逡巡","须臾","瞬息","弹指","刹那","六德","空虚","☆清静" };
public Form1()
{
InitializeComponent();
}
private void Form1_Load(object sender, EventArgs e)
{
ToolTip KjTs = new ToolTip();
KjTs.SetToolTip(ZhuanHuang, "单击执行转换");
KjTs.SetToolTip(XuanXiang, "请选择要执行小数的“四舍五入”位数");
KjTs.SetToolTip(Kuo, "选择该项时将强行扩展整数的位数到万无量=[不可说],没有实际意义。");
}
private void ZhuanHuang_Click(object sender, EventArgs e)
{
string DD_BM = SuZi.Text.Trim(); string[] Fg = new string[2];
try
{
if (SuZi.Text.Length > 99 || SuZi.Text == "")
{
if (SuZi.Text.Length > 99)
MessageBox.Show("1、操作非法,输入数值超过范围,无法计算!请重新输入小等于69位整数(强制扩展:小等于76位)和小等于22位小数!", "友情提示!", MessageBoxButtons.OK, MessageBoxIcon.Information);
if (SuZi.Text == "")
MessageBox.Show("2、操作非法!请重新输入小等于69位整数(强制扩展:小等于76位)和小等于22位小数!", "友情提示!", MessageBoxButtons.OK, MessageBoxIcon.Information);
}
else
{
string GuoLvZiFu = DD_BM;
ZongWenSuZhi.Text = ""; SsWr = 0;
do { GuoLvZiFu = 过滤(GuoLvZiFu, false); }
while (PanDuan == false);//再循环
DD_BM = GuoLvZiFu;
if (ZzS.Checked)
{
do { GuoLvZiFu = 过滤(GuoLvZiFu, true); }
while (PanDuan == false);//再循环
DD_BM = GuoLvZiFu;
if (DD_BM.IndexOf("元") >= 0) { Fg = DD_BM.Split('元'); } //整数
else { Fg[0] = ""; Fg[1] = DD_BM; }//纯小数
}
if (SzZ.Checked) Fg = DD_BM.Split('.');
if (ZzS.Checked)//中文→数字
{
if (Fg[0] != "") //整数部分
{
if (Zhuan.Checked) ZongWenSuZhi.Text = Zh_Zwz(ZzZhengShu(Fg[0]), "中文→数字整数", true);
if (!Zhuan.Checked) ZongWenSuZhi.Text = ZzZhengShu(Fg[0]);
}
if (Fg.Length == 2 && Fg[1] != "") //小数部分
{
if (Zhuan.Checked) ZongWenSuZhi.Text += Zh_Zwz(XiaoShu(Fg[1], ZzS.Checked), "中文→数字小数", true);
if (!Zhuan.Checked) ZongWenSuZhi.Text += XiaoShu(Fg[1], ZzS.Checked);
}
}
if (SzZ.Checked)//数字→中文
{
if (!Kuo.Checked)//不扩展
{
if (Fg[0].Length <= 69) ZhRk(Fg);
else MessageBox.Show("3、操作非法,请重新输入小于69位整数和小于22位小数,如果大于以上整数部分需要转换请选择[强制扩展],友情提醒[强制扩展]是无意义的数字,故曰:不可说!", "友情提示!", MessageBoxButtons.OK, MessageBoxIcon.Information);
}
if (Kuo.Checked)//扩展
{
if (Fg[0].Length <= 76) ZhRk(Fg);
else MessageBox.Show("4、操作非法,请重新输入[强制扩展]小于76位整数和小于22位小数!", "友情提示!", MessageBoxButtons.OK, MessageBoxIcon.Information);
}
}
}
}
catch (Exception)
{ }
}
private void ZhRk(string[] Fg)//数字-中文转换入口
{
try
{
if (!Zhuan.Checked) ZongWenSuZhi.Text = Zh_Zwz(Fg[0], "数字→中文整数", false);
if (Zhuan.Checked) ZongWenSuZhi.Text = TiHuan(Zh_Zwz(Fg[0], "数字→中文整数", false));
if (Fg.Length == 1) ZongWenSuZhi.Text = ZongWenSuZhi.Text + "整";
if (Fg.Length == 2 && Fg[1] != "")//小数
{
if (Fg[1].Length > 22) { Fg[1] = Fg[1].Substring(0, 22); MessageBox.Show("6、操作非法,请重新输入小等于22位小数,大于22位时将截取自左开始到22位的数字,22位后面的数字不被列入转换范围!", "友情提示!", MessageBoxButtons.OK, MessageBoxIcon.Information); }//截取位数
if (XuanXiang.Text != "四舍五入") Fg[1] = SheRu(Fg[1], "五入");
if (SiLiu.Text != "四舍六入") Fg[1] = SheRu(Fg[1], "六入");
if (!Zhuan.Checked) ZongWenSuZhi.Text += Zh_Zwz(Fg[1], "数字→中文小数", false);
if (Zhuan.Checked) ZongWenSuZhi.Text += TiHuan(Zh_Zwz(Fg[1], "数字→中文小数", false));
}
}
catch (Exception)
{ }
}
private string Zh_Zwz(string DD_BM, string BiaoJi, bool Zs)//[等效]转换中文/数值
{
string Sz = "";
try
{
for (int Qs = 0; Qs < DD_BM.Length; Qs++)
{
string Zf = DD_BM.Substring(Qs, 1);//依循环取其中一个字符
if (Bj.IndexOf(Zf) >= 0 && !Zs)//比较
{ Sz += Zz.Substring(Bj.IndexOf(Zf), 1); } //等效中文
if (Zz.IndexOf(Zf) >= 0 && Zs)
{ Sz += Bj.Substring(Zz.IndexOf(Zf), 1); }//等效数字
}
if (BiaoJi == "中文→数字小数") Sz = "." + Sz;//补
if (BiaoJi == "数字→中文小数") Sz = XiaoShu(Sz, false);
if (BiaoJi == "数字→中文整数") Sz = SzZhengShu(Sz);
}
catch (Exception)
{ }
return Sz;
}
private string ZzZhengShu(string ZsBf)//中文→数字整数部分
{
string ZsB = ZsBf + "元";
try
{
do { ZsB = BuWei(ZsB); }
while (PanDuan == false);//再循环
}
catch (Exception e)
{ }
finally { }
return ZsB;
}
private string 过滤(string GuoLv, bool Gv)
{
string ZhongWen = "", Bij = "", SzHc = "";
try
{
if (Gv)//中文→数字过滤数字小数点
{
for (int Gl = GuoLv.Length - 1; Gl >= 0; Gl--)
{
Bij = GuoLv.Substring(Gl, 1);
if (("." + Bj).IndexOf(Bij) >= 0)
{ GuoLv = GuoLv.Replace(Bij, ""); PanDuan = false; break; }
else { PanDuan = true; }
}
}
if (!Gv) //消除所有以外的字符
{
for (int Hcf = 0; Hcf < Jz.Length; Hcf++)
{ SzHc += Jz[Hcf]; }
for (int Hcf = 0; Hcf < Zs.Length; Hcf++)
{ SzHc += Zs[Hcf]; }
for (int Hcf = 0; Hcf < Xs.Length; Hcf++)
{ SzHc += Xs[Hcf]; }
SzHc += "." + Zz + Bj;
for (int Gg = 0; Gg < GuoLv.Length; Gg++)
{
Bij = GuoLv.Substring(Gg, 1);
if (SzHc.IndexOf(Bij) < 0)
{ GuoLv = GuoLv.Replace(Bij, ""); PanDuan = false; break; }
else { PanDuan = true; }
}
}
}
catch (Exception)
{ }
return ZhongWen = GuoLv;
}
}
}