c#中怎么把科学计数法转换成普通c 数值转换

DataTable导出到Excel时身份证号信息自动转换为科学计数法的解决方案-asp.net-电脑编程网DataTable导出到Excel时身份证号信息自动转换为科学计数法的解决方案作者:wlitsoft%26lt%3b%e6%9d%8e%e4%ba%ae%26gt%3b 和相关&&做项目的时候是否遇到过这种问题,我今天遇到了就给大家分享下,在网上找的答案都是针对gridview控件的,还有就是该DataTable的身份证号列的类型为string,再有就是前面加单引号什么的,但是我都没有试验成功不知道是我人品的问题还是真不行,但是今天我整的这个方案完美避开了科学计数法 呵呵 废话少说上代码
1 DataTable dt = new DataTable();2
dt.Columns.Add(new DataColumn("身份证号"));3
DataRow dr = dt.NewRow();4
StringBuilder sb = new StringBuilder("=\"");5
sb.Append("3456789").Append("\"");6
dr[0] = sb.ToString();7
dt.Rows.Add(dr);8
ImportAndExport.CreateExcel(dt, "1", "11.xls");
嘿嘿 够简单吧!原理就是Excel会自动把="3456789"认为计算字符串的公式 嘿嘿,不信的请新建个Exel文件试试 相关资料:|||||||DataTable导出到Excel时身份证号信息自动转换为科学计数法的解决方案来源网络,如有侵权请告知,即处理!编程Tags:                &                    c#如何将科学计数法转换为普通计数法本人c#初学者.double a=0.0000007;string b=a.Tostring();显示出来的b总是7E-7,而不是0.0000007,请问有什么办法解决吗?其实我想解决的是这一类的问题,如果只知道a是一个小数,而不知道它具体是多少位的,就不好解决了,我过我刚才已经找到办法了,
string b=a.Tostring("0.");
为您推荐:
其他类似问题
扫描下载二维码Posts - 212,
Articles - 0,
Comments - 395
14:14 by hongjiumu, ... 阅读,
关于数字右对齐和用0填充格式化字符串的方法
在向文件或者报表输出数字的时候,固定字符串的长度向右对齐,用0填充其余空间的情况很常见。在这种情况下,使用String类(System名称空间)的Format方法就很方便。Format方法可以用参数设置字符串的格式以及指定相应的对象变量,本文提取一些经常用到的数字变换成字符串的情形进行介绍。
使用Format方法把数字夹杂在字符串中输出在介绍数字的输出格式之前,首先回顾一下Format方法的基本用法。Format方法的常用情形,就像以下的代码这样把变量夹杂在字符串中处理然后输出。
string name = "鈴木";int month = 1;int day = 30;string str = String.Format("{0}先生、今日是{1}月{2}日。", name, month, day);// 变量str的内容:鈴木先生、今日是1月30日。
Dim name As String = "鈴木"Dim month As Integer = 1Dim day As Integer = 30Dim str As String = String.Format( _"{0}先生、今日是{1}月{2}日。", name, month, day)' 变量str的内容:鈴木先生、今日是1月30日。
Format方法的使用例子(上:C#、下:VB)
在这里,Format方法的第一个参数是用来指定字符串格式的,它往往通过在普通字符串中插入诸如{0}或{1}这样的修饰项目来实现。这种修饰项目是用大括号把从0开始1,2,3这样的数字序列号包起来。在时,把序号对应的对象转换成字符串替换即可。上述的例子就是,字符串str的值是:鈴木先生、今日是1月30日。
注,所有的对象都通过调用ToString方法来转换成字符串。数字的格式指定可以通过往刚才所说的修饰项目中添加几个参数来实现控制数字格式的目的。下表列出了几个常见的例子。
固定宽度右对齐
String.Format("{0, 4}", num)
固定宽度左对齐
String.Format("{0, -4}", num)
String.Format("{0:D4}", num)或者String.Format("{0:0000}", num)
固定宽度并用0填充
String.Format("{0, 8:D4}", num)
常用的指定数字数字输出格式的例子
这个表前两项指定了生成字符串的宽度。这只需要在序列号的后面加上 &,整数字& 这样的内容即可。负数的情况下表示左对齐。第三项是用0填充空位的例子。这又有两种方法。一种是形如{0:D4}这样,在索引号后加上冒号,然后加上D(表示十进制,Decimal,如果是十六进制的话,就用X)加上表示宽度的整数(这里例子是4)。这种表示方法叫做&标准数字格式字符串&,具体可以参考MSDN的『标准数字格式字符串』。用0填充的另一种方法是{0:0000},在序列号后加上冒号加上宽度等同数值个数的填充字符(也叫做占位符,英文placeholder。这里是4个0,也可以是4个1,4个2)。具体可以参考MSDN的『自定义数字格式字符串』。
表中最后一项演示了指定字符串的宽度,并且用0填充空余位置的方法。标准的语法是
{索引号, 字符串宽度:格式描述符}
格式指定的语法
Format方法的例子程序下面,先看看几个实例程序
// formatint.csusing Spublic class FormatInteger {static void Main() {int zero = 0;int eleven = 11;//// 例1output = String.Format("4位右对齐【{0, 4}】", zero);Console.WriteLine(output);// 输出:4位右对齐【 0】output = String.Format("4位右对齐【{0, 4}】", eleven);Console.WriteLine(output);//&输出:4位右对齐【 11】//// 例2Console.WriteLine ("【{0, 4}】【{1, 4}】", zero, eleven);//&输出:【 0】【 11】//// 例3Console.WriteLine("4位左对齐【{0, -4}】", zero);//&输出:4位左对齐【0 】Console.WriteLine("4位左对齐【{0, -4}】", eleven);//&输出:4位左对齐【11 】Console.WriteLine("4位0填充【{0:D4}】", zero);//&输出:4位0填充【0000】Console.WriteLine("4位0填充【{0:D4}】", eleven);//&输出:4位0填充【0011】Console.WriteLine("4位0填充【{0:0000}】", zero);//&输出:4位0填充【0000】Console.WriteLine("4位0填充【{0:0000}】", eleven);//&输出:4位0填充【0011】Console.WriteLine("8位长度4位0填充【{0, 8:D4}】", zero);//&输出:8位长度4位0填充【 0000】Console.WriteLine("8位长度4位0填充【{0, 8:D4}】", eleven);//&输出:8位长度4位0填充【 0011】//// 例4Console.WriteLine("【{0, 4}】【{0, -4}】【{0:D4}】【{0:0000}】", eleven);//&输出:【 11】【11 】【0011】【0011】}}// 编译方法:csc formatint.cs
Format方法的C#实例程序(formatint.cs)
' formatint.vbImports SystemPublic Class FormatIntegerShared Sub Main()Dim output As StringDim zero As Integer = 0Dim eleven As Integer = 11'''' 例1output = String.Format("4けた右詰め【{0, 4}】", zero)Console.WriteLine(output)'&输出:4けた右詰め【 0】output = String.Format("4けた右詰め【{0, 4}】", eleven)Console.WriteLine(output)'&输出:4けた右詰め【 11】'''' 例2Console.WriteLine ("【{0, 4}】【{1, 4}】", zero, eleven)'&输出:【 0】【 11】'''' 例3Console.WriteLine("4けた左詰め【{0, -4}】", zero)'&输出:4けた左詰め【0 】Console.WriteLine("4けた左詰め【{0, -4}】", eleven)'&输出:4けた左詰め【11 】Console.WriteLine("4けた0埋め【{0:D4}】", zero)'&输出:4けた0埋め【0000】Console.WriteLine("4けた0埋め【{0:D4}】", eleven)'&输出:4けた0埋め【0011】Console.WriteLine("4けた0埋め【{0:0000}】", zero)'&输出:4けた0埋め【0000】Console.WriteLine("4けた0埋め【{0:0000}】", eleven)'&输出:4けた0埋め【0011】Console.WriteLine("8けたかつ4けた0埋め【{0, 8:D4}】", zero)'&输出:8けたかつ4けた0埋め【 0000】Console.WriteLine("8けたかつ4けた0埋め【{0, 8:D4}】", eleven)'&输出:8けたかつ4けた0埋め【 0011】'''' 例4Console.WriteLine( _"【{0, 4}】【{0, -4}】【{0:D4}】【{0:0000}】", eleven)'&输出:【 11】【11 】【0011】【0011】End SubEnd Class' 编译方法:vbc formatint.vb
其它格式:
C#:String.Format数字格式化输出
int a = ;&&&//格式为sring输出//&&&Label1.Text = string.Format("asdfadsf{0}adsfasdf",a);//&&&Label2.Text = "asdfadsf"+a.ToString()+"adsfasdf";//&&&Label1.Text = string.Format("asdfadsf{0:C}adsfasdf",a);//asdfadsf¥1,234.00adsfasdf//&&&Label2.Text = "asdfadsf"+a.ToString("C")+"adsfasdf";//asdfadsf¥1,234.00adsfasdf
&&&double b = ;&&&a = ;&&&//格式为特殊的string样式输出//&&&Label1.Text = string.Format("asdfadsf{0:C}adsfasdf",b);//asdfadsf¥1,234.13adsfasdf//&&&Label2.Text = "asdfadsf"+b.ToString("C")+"adsfasdf";//asdfadsf¥1,234.13adsfasdf//&&&Label1.Text = string.Format("{0:C3}",b);//¥1,234.125//&&&Label2.Text = b.ToString("C3");//¥1,234.125//&&&Label1.Text = string.Format("{0:d}",a);//十进制--//&&&Label2.Text = b.ToString("d");//十进制--相同的类型,转换报错//&&&Label1.Text = string.Format("{0:e}",a);//指数--1.7//&&&Label2.Text = b.ToString("e");//指数--1.3
//&&&Label1.Text = string.Format("{0:f}",a);//定点数--//&&&Label2.Text = b.ToString("f");//定点数--1234.13//&&&Label1.Text = string.Format("{0:n}",a);//数值--12,345,678.00//&&&Label2.Text = b.ToString("n");//数值--1,234.13//&&&Label1.Text = string.Format("{0:x}",a);//十六进制--bc614e//&&&Label2.Text = b.ToString("x");//16--带有小数不能转换,出错//&&&Label1.Text = string.Format("{0:g}",a);//通用为最紧凑--//&&&Label2.Text = b.ToString("g");//通用为最紧凑--//&&&Label1.Text = string.Format("{0:r}",a);//转来转去不损失精度--整数不允许用,报错//&&&Label2.Text = b.ToString("r");//转来转去不损失精度--&&&&&b = ;&&&a = 1234;&&&//自定义模式输出://&&&0 描述:占位符,如果可能,填充位//&&&Label1.Text = string.Format("{0:000000}",a);// 001234//&&&Label2.Text = string.Format("{0:000000}",b);// 004321//&&&# 描述:占位符,如果可能,填充位//&&&Label1.Text = string.Format("{0:#######}",a);// 1234//&&&Label2.Text = string.Format("{0:#######}",b);// 4321//&&&Label1.Text = string.Format("{0:#0####}",a);// 01234//&&&Label2.Text = string.Format("{0:0#0000}",b);// 004321
//&&&. 描述:小数点//&&&Label1.Text = string.Format("{0:000.000}",a);////&&&Label2.Text = string.Format("{0:000.000}",b);//&&&b = 43;&&&a = ;//&&&, 描述:数字分组,也用于增倍器//&&&Label1.Text = string.Format("{0:0,00}",a);// 12,345,678//&&&Label2.Text = string.Format("{0:0,00}",b);// 87,654,32//&&&Label1.Text = string.Format("{0:0,}",a);// 12346//&&&Label2.Text = string.Format("{0:0,}",b);// 87654//&&&Label1.Text = string.Format("{0:0,,}",a);// 12//&&&Label2.Text = string.Format("{0:0,,}",b);// 88//&&&Label1.Text = string.Format("{0:0,,,}",a);// 0//&&&Label2.Text = string.Format("{0:0,,,}",b);// 0//&&&% 描述:格式为百分数//&&&Label1.Text = string.Format("{0:0%}",a);// %//&&&Label2.Text = string.Format("{0:#%}",b);// %//&&&Label1.Text = string.Format("{0:0.00%}",a);// .00%//&&&Label2.Text = string.Format("{0:#.00%}",b);// .54%//&&&'abc' 描述:显示单引号内的文本//&&&Label1.Text = string.Format("{0:'文本'0}",a);// 文本//&&&Label2.Text = string.Format("{0:文本0}",b);// 文本//&&&\ 描述:后跟1要打印字的字符,也用于转移符\n等//&&&Label1.Text = string.Format("\"你好!\"");// "你好!"//&&&Label2.Text = string.Format("//&&&@描述:后跟要打印字的字符,//&&&Label1.Text = string.Format(@"""你好!"""); // "你好!"要打印"则需要输入两对才可以//&&&Label2.Text = string.Format(@"\c\books\new\we.asp");//\c\books\new\we.asp
格式 原始数据 结 果"{0:P}" 0.40 40%
数字 {0:N2} 12.36&数字 {0:N0} 13&货币 {0:c2} $12.36&货币 {0:c4} $12.3656&货币 "¥{0:N2}" ¥12.36&科学计数法 {0:E3} 1.23E+001&百分数 {0:P} 12.25% P and p present the same.日期 {0:D} 日&日期 {0:d} &日期 {0:f} 日 10:30&日期 {0:F} 日 10:30:00&日期 {0:s}
10:30:00&时间 {0:T} 10:30:00
DateTime dt = DateTime.NLabel1.Text = dt.ToString();// 13:21:25Label2.Text = dt.ToFileTime().ToString();//912816Label3.Text = dt.ToFileTimeUtc().ToString();//912816Label4.Text = dt.ToLocalTime().ToString();// 21:21:25Label5.Text = dt.ToLongDateString().ToString();//日Label6.Text = dt.ToLongTimeString().ToString();//13:21:25Label7.Text = dt.ToOADate().ToString();//8218Label8.Text = dt.ToShortDateString().ToString();//Label9.Text = dt.ToShortTimeString().ToString();//13:21Label10.Text = dt.ToUniversalTime().ToString();// 5:21:25
Label1.Text = dt.Year.ToString();//2005Label2.Text = dt.Date.ToString();// 0:00:00Label3.Text = dt.DayOfWeek.ToString();//SaturdayLabel4.Text = dt.DayOfYear.ToString();//309Label5.Text = dt.Hour.ToString();//13Label6.Text = dt.Millisecond.ToString();//441Label7.Text = dt.Minute.ToString();//30Label8.Text = dt.Month.ToString();//11Label9.Text = dt.Second.ToString();//28Label10.Text = dt.Ticks.ToString();//412864Label11.Text = dt.TimeOfDay.ToString();//13:30:28.4412864
Label1.Text = dt.ToString();// 13:47:04Label2.Text = dt.AddYears(1).ToString();// 13:47:04Label3.Text = dt.AddDays(1.1).ToString();// 16:11:04Label4.Text = dt.AddHours(1.1).ToString();// 14:53:04Label5.Text = dt.AddMilliseconds(1.1).ToString();// 13:47:04Label6.Text = dt.AddMonths(1).ToString();// 13:47:04Label7.Text = dt.AddSeconds(1.1).ToString();// 13:47:05Label8.Text = dt.AddMinutes(1.1).ToString();// 13:48:10Label9.Text = dt.AddTicks(1000).ToString();// 13:47:04Label10.Text = dt.CompareTo(dt).ToString();//0Label11.Text = dt.Add(?).ToString();//问号为一个时间段
Label1.Text = dt.Equals(" 16:11:04").ToString();//FalseLabel2.Text = dt.Equals(dt).ToString();//TrueLabel3.Text = dt.GetHashCode().ToString();//Label4.Text = dt.GetType().ToString();//System.DateTimeLabel5.Text = dt.GetTypeCode().ToString();//DateTime
Label1.Text = dt.GetDateTimeFormats('s')[0].ToString();//T14:06:25Label2.Text = dt.GetDateTimeFormats('t')[0].ToString();//14:06Label3.Text = dt.GetDateTimeFormats('y')[0].ToString();//2005年11月Label4.Text = dt.GetDateTimeFormats('D')[0].ToString();//日Label5.Text = dt.GetDateTimeFormats('D')[1].ToString();//Label6.Text = dt.GetDateTimeFormats('D')[2].ToString();//星期六 Label7.Text = dt.GetDateTimeFormats('D')[3].ToString();//星期六 日Label8.Text = dt.GetDateTimeFormats('M')[0].ToString();//11月5日Label9.Text = dt.GetDateTimeFormats('f')[0].ToString();//日 14:06Label10.Text = dt.GetDateTimeFormats('g')[0].ToString();// 14:06Label11.Text = dt.GetDateTimeFormats('r')[0].ToString();//Sat, 05 Nov :25 GMT
Label1.Text = string.Format("{0:d}",dt);//Label2.Text = string.Format("{0:D}",dt);//日Label3.Text = string.Format("{0:f}",dt);//日 14:23Label4.Text = string.Format("{0:F}",dt);//日 14:23:23Label5.Text = string.Format("{0:g}",dt);// 14:23Label6.Text = string.Format("{0:G}",dt);// 14:23:23Label7.Text = string.Format("{0:M}",dt);//11月5日Label8.Text = string.Format("{0:R}",dt);//Sat, 05 Nov :23 GMTLabel9.Text = string.Format("{0:s}",dt);//T14:23:23Label10.Text&&&string.Format("{0:t}",dt);//14:23Label11.Text = string.Format("{0:T}",dt);//14:23:23Label12.Text = string.Format("{0:u}",dt);// 14:23:23ZLabel13.Text = string.Format("{0:U}",dt);//日 6:23:23Label14.Text = string.Format("{0:Y}",dt);//2005年11月Label15.Text = string.Format("{0}",dt);// 14:23:23Label16.Text = string.Format("{0:yyyyMMddHHmmssffff}",dt);
stringstr1 =string.Format("{0:N1}",56789);&&&&&&&&&&&&&&&&//result: 56,789.0stringstr2 =string.Format("{0:N2}",56789);&&&&&&&&&&&&&&&&//result: 56,789.00stringstr3 =string.Format("{0:N3}",56789);&&&&&&&&&&&&&&&&//result: 56,789.000stringstr8 =string.Format("{0:F1}",56789);&&&&&&&&&&&&&&&&//result: 56789.0stringstr9 =string.Format("{0:F2}",56789);&&&&&&&&&&&&&&&&//result: 56789.00stringstr11 =(56789 / 100.0).ToString("#.##");&&&&&&&&&&&&//result: 567.89stringstr12 =(56789 / 100).ToString("#.##");&&&&&&&&&&&&&&//result: 567
C 或 c货币Console.Write("{0:C}", 2.5);&&&//$2.50Console.Write("{0:C}", -2.5); //($2.50)
D 或 d十进制数Console.Write("{0:D5}", 25);&&&//00025
E 或 e科学型Console.Write("{0:E}", 250000);&&&//2.5
F 或 f固定点Console.Write("{0:F2}", 25);&&&//25.00Console.Write("{0:F0}", 25);&&&//25
G 或 g常规Console.Write("{0:G}", 2.5);&&&//2.5
N 或 n数字Console.Write("{0:N}", 2500000);&&&//2,500,000.00
X 或 x十六进制Console.Write("{0:X}", 250);&&&//FAConsole.Write("{0:X}", 0xffff);&&&//FFFF本帖子已过去太久远了,不再提供回复功能。}

我要回帖

更多关于 python科学计数法转换 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信