01. double pi = 3.1415927;//pi 02. // 取一位整数 03. System.out.println(new DecimalFormat("0").format(pi));// 3 04. // 取一位整数和两位小数 05. System.out.println(new DecimalFormat("0.00").format(pi));// 3.14 06. // 取两位整数和三位小数,整数不足部分以0填补。 07. System.out.println(new DecimalFormat("00.000").format(pi));// 03.142 08. // 取所有整数部分 09. System.out.println(new DecimalFormat("#").format(pi));// 3 10. // 以百分比方式计数,并取两位小数 11. System.out.println(new DecimalFormat("#.##%").format(pi));// 314.16% 12. 13. long c = 299792458; 14. // 显示为科学计数法,并取五位小数 15. System.out.println(new DecimalFormat("#.#####E0").format(c));// 2.99792E8 16. // 显示为两位整数的科学计数法,并取四位小数 17. System.out.println(new DecimalFormat("00.####E0").format(c));// 29.9792E7 18. // 每三位以逗号进行分隔。 19. System.out.println(new DecimalFormat(",###").format(c));// 299,792,458 20. // 将格式嵌入文本 21. System.out.println(new DecimalFormat("光速大小为每秒,###米。").format(c));
<div class="iteye-blog-content-contain" style="font-size: 14px"></div>
01.double pi = 3.1415927;//pi 02. // 取一位整数 03. System.out.println(new DecimalFormat("0").format(pi));// 3 04. // 取一位整数和两位小数 05. System.out.println(new DecimalFormat("0.00").format(pi));// 3.14 06. // 取两位整数和三位小数,整数不足部分以0填补。 07. System.out.println(new DecimalFormat("00.000").format(pi));// 03.142 08. // 取所有整数部分 09. System.out.println(new DecimalFormat("#").format(pi));// 3 10. // 以百分比方式计数,并取两位小数 11. System.out.println(new DecimalFormat("#.##%").format(pi));// 314.16% 12. 13. long c = 299792458; 14. // 显示为科学计数法,并取五位小数 15. System.out.println(new DecimalFormat("#.#####E0").format(c));// 2.99792E8 16. // 显示为两位整数的科学计数法,并取四位小数 17. System.out.println(new DecimalFormat("00.####E0").format(c));// 29.9792E7 18. // 每三位以逗号进行分隔。 19. System.out.println(new DecimalFormat(",###").format(c));// 299,792,458 20. // 将格式嵌入文本 21. System.out.println(new DecimalFormat("光速大小为每秒,###米。").format(c));
DecimalFormat 类主要靠 # 和 0 两种占位符号来指定数字长度。0 表示如果位数不足则以 0 填充,# 表示只要有可能就把数字拉上这个位置。
有时我们需要控制输出的数字的格式,如何使用java的类库做到这个呢?
也许你不关心格式,但是你需要关心你的程序可以在全世界通用,像下面的这样一个简单的语句是依赖地区的:
System.out.println(1234.56);
在美国,"." 是小数点,但在其它地方就不一定了。如何处理这个呢?
java.text 包中的一些包可以处理这类问题。下面的简单范例使用那些类解决上面提出的问题:
01.import java.text.NumberFormat; 02. import java.util.Locale; 03. public class DecimalFormat1 { 04. public static void main(String args[]) { 05. // 得到本地的缺省格式 06. NumberFormat nf1 = NumberFormat.getInstance(); 07. System.out.println(nf1.format(1234.56)); 08. // 得到德国的格式 09. NumberFormat nf2 = 10. NumberFormat.getInstance(Locale.GERMAN); 11. System.out.println(nf2.format(1234.56)); 12. } 13. }
01.import java.text.NumberFormat; 02. import java.util.Locale; 03. public class DecimalFormat1 { 04. public static void main(String args[]) { 05. // 得到本地的缺省格式 06. NumberFormat nf1 = NumberFormat.getInstance(); 07. System.out.println(nf1.format(1234.56)); 08. // 得到德国的格式 09. NumberFormat nf2 = 10. NumberFormat.getInstance(Locale.GERMAN); 11. System.out.println(nf2.format(1234.56)); 12. } 13. }
如果你在美国,运行程序后输出:
1,234.56
1.234,56
换句话说,在不同的地方使用不同的习惯表示数字。
NumberFormat.getInstance()方法返回NumberFormat的一个实例(实际上是NumberFormat具体的一个子类,例如DecimalFormat), 这适合根据本地设置格式化一个数字。你也可以使用非缺省的地区设置,例如德国。然后格式化方法根据特定的地区规则格式化数字。这个程序也可以使用一个简单的形式:
NumberFormat.getInstance().format(1234.56)
但是保存一个格式然后重用更加有效。国际化是格式化数字时的一个大问题。
另一个是对格式的有效控制,例如指定小数部分的位数,下面是解决这个问题的一个简单例子:
01.import java.text.DecimalFormat; 02. import java.util.Locale; 03. public class DecimalFormat2 { 04. public static void main(String args[]) { 05. // 得到本地的缺省格式 06. DecimalFormat df1 = new DecimalFormat("####.000"); 07. System.out.println(df1.format(1234.56)); 08. // 得到德国的格式 09. Locale.setDefault(Locale.GERMAN); 10. DecimalFormat df2 = new DecimalFormat("####.000"); 11. System.out.println(df2.format(1234.56)); 12. } 13. }
01.import java.text.DecimalFormat; 02. import java.util.Locale; 03. public class DecimalFormat2 { 04. public static void main(String args[]) { 05. // 得到本地的缺省格式 06. DecimalFormat df1 = new DecimalFormat("####.000"); 07. System.out.println(df1.format(1234.56)); 08. // 得到德国的格式 09. Locale.setDefault(Locale.GERMAN); 10. DecimalFormat df2 = new DecimalFormat("####.000"); 11. System.out.println(df2.format(1234.56)); 12. } 13. }
在这个例子中设置了数字的格式,使用像"####.000"的符号。这个模式意味着在小数点前有四个数字,如果不够就空着,小数点后有三位数字,不足用0补齐。程序的输出:
1234.560
1234,560
相似的,也可以控制指数形式的格式,例如:
01.import java.text.DecimalFormat; 02. public class DecimalFormat3 { 03. public static void main(String args[]) { 04. DecimalFormat df = new DecimalFormat("0.000E0000"); 05. System.out.println(df.format(1234.56)); 06. } 07. }
01.import java.text.DecimalFormat; 02. public class DecimalFormat3 { 03. public static void main(String args[]) { 04. DecimalFormat df = new DecimalFormat("0.000E0000"); 05. System.out.println(df.format(1234.56)); 06. } 07. }
输出:
1.235E0003
对于百分数:
02.import java.text.NumberFormat; 03. public class DecimalFormat4 { 04. public static void main(String args[]) { 05. NumberFormat nf = NumberFormat.getPercentInstance(); 06. System.out.println(nf.format(0.47)); 07. } 08. }
import java.text.NumberFormat; 03. public class DecimalFormat4 { 04. public static void main(String args[]) { 05. NumberFormat nf = NumberFormat.getPercentInstance(); 06. System.out.println(nf.format(0.47)); 07. } 08. }
输出:
47%
至此,你已经看到了格式化数字的几个不同的技术。另一方面,如何读取并解析包含格式化的数字的字符串?解析支持包含在NumberFormat中。例如:
01.import java.util.Locale; 02. import java.text.NumberFormat; 03. import java.text.ParseException; 04. public class DecimalFormat5 { 05. public static void main(String args[]) { 06. // 本地格式 07. NumberFormat nf1 = NumberFormat.getInstance(); 08. Object obj1 = null; 09. // 基于格式的解析 10. try { 11. obj1 = nf1.parse("1234,56"); 12. } 13. catch (ParseException e1) { 14. System.err.println(e1); 15. } 16. System.out.println(obj1); 17. // 德国格式 18. NumberFormat nf2 = 19. NumberFormat.getInstance(Locale.GERMAN); 20. Object obj2 = null; 21. // 基于格式的解析 22. try { 23. obj2 = nf2.parse("1234,56"); 24. } 25. catch (ParseException e2) { 26. System.err.println(e2); 27. } 28. System.out.println(obj2); 29. } 30. }
01.import java.util.Locale; 02. import java.text.NumberFormat; 03. import java.text.ParseException; 04. public class DecimalFormat5 { 05. public static void main(String args[]) { 06. // 本地格式 07. NumberFormat nf1 = NumberFormat.getInstance(); 08. Object obj1 = null; 09. // 基于格式的解析 10. try { 11. obj1 = nf1.parse("1234,56"); 12. } 13. catch (ParseException e1) { 14. System.err.println(e1); 15. } 16. System.out.println(obj1); 17. // 德国格式 18. NumberFormat nf2 = 19. NumberFormat.getInstance(Locale.GERMAN); 20. Object obj2 = null; 21. // 基于格式的解析 22. try { 23. obj2 = nf2.parse("1234,56"); 24. } 25. catch (ParseException e2) { 26. System.err.println(e2); 27. } 28. System.out.println(obj2); 29. } 30. }
这个例子分两部分,都是解析一个字符串:"1234,56"。第一部分使用本地格式解析,第二部分使用德国格式解析。当程序在美国运行,结果是:
123456
1234.56
换句话说,"1234,56"在美国被认为是一个巨大的整数"123456"而在德国被认为是一个小数"1234.56"。
还有格式化讨论的最后一个问题。在上面的例子中, DecimalFormat 和 NumberFormat 都被使用了。DecimalFormat 常用于获得很好的格式控制,而NumberFormat 常用于指定不同于本地的地区。如何结合两个类呢?
答案围绕着这样的事实:DecimalFormat是NumberFormat的一个子类,其实例被指定为特定的地区。因此,你可以使用NumberFormat.getInstance 指定一个地区,然后将结构强制转换为一个DecimalFormat对象。文档中提到这个技术可以在大多情况下适用,但是你需要用try/catch 块包围强制转换以防转换不能正常工作 (大概在非常不明显得情况下使用一个奇异的地区)。下面是一个这样的例子:
02.import java.text.DecimalFormat; 03. import java.text.NumberFormat; 04. import java.util.Locale; 05. public class DecimalFormat6 { 06. public static void main(String args[]) { 07. DecimalFormat df = null; 08. // 得到一个NumberFormat 对象并 09. // 强制转换为一个 DecimalFormat 对象 10. try { 11. df = (DecimalFormat) 12. NumberFormat.getInstance(Locale.GERMAN); 13. } 14. catch (ClassCastException e) { 15. System.err.println(e); 16. } 17. // 设置格式模式 18. df.applyPattern("####.00000"); 19. // format a number 20. System.out.println(df.format(1234.56)); 21. } 22. }
import java.text.DecimalFormat; 03. import java.text.NumberFormat; 04. import java.util.Locale; 05. public class DecimalFormat6 { 06. public static void main(String args[]) { 07. DecimalFormat df = null; 08. // 得到一个NumberFormat 对象并 09. // 强制转换为一个 DecimalFormat 对象 10. try { 11. df = (DecimalFormat) 12. NumberFormat.getInstance(Locale.GERMAN); 13. } 14. catch (ClassCastException e) { 15. System.err.println(e); 16. } 17. // 设置格式模式 18. df.applyPattern("####.00000"); 19. // format a number 20. System.out.println(df.format(1234.56)); 21. } 22. }
getInstance() 方法获得格式,然后调用applyPattern()方法设置格式模式,输出:
1234,56000
如果你不关心国际化,可以直接使用DecimalFormat
01.DecimalFormat df1 = new DecimalFormat("###.00"); 02. System.out.println(df1.format(234234.234634)); 03. System.out.println(df1.format(34.234634)); 04. 05. DecimalFormat df2 = new DecimalFormat("0.00E0000"); 06. System.out.println(df2.format(23423.34234234)); 07. 08. DecimalFormat df3 = (DecimalFormat)NumberFormat.getInstance(Locale.CHINESE); 09. df3.applyPattern("####.000"); 10. System.out.println(df3.format(23423.34234234)); 11. df3.applyPattern("00.0000%"); 12. System.out.println(df3.format(0.5552445)); 13. 14. NumberFormat nf1 = NumberFormat.getInstance(); 15. System.out.println(nf1.format(13423423.234234)); 16. 17. NumberFormat nf2 = NumberFormat.getPercentInstance(); 18. System.out.println(nf2.format(0.55));
01.DecimalFormat df1 = new DecimalFormat("###.00"); 02. System.out.println(df1.format(234234.234634)); 03. System.out.println(df1.format(34.234634)); 04. 05. DecimalFormat df2 = new DecimalFormat("0.00E0000"); 06. System.out.println(df2.format(23423.34234234)); 07. 08. DecimalFormat df3 = (DecimalFormat)NumberFormat.getInstance(Locale.CHINESE); 09. df3.applyPattern("####.000"); 10. System.out.println(df3.format(23423.34234234)); 11. df3.applyPattern("00.0000%"); 12. System.out.println(df3.format(0.5552445)); 13. 14. NumberFormat nf1 = NumberFormat.getInstance(); 15. System.out.println(nf1.format(13423423.234234)); 16. 17. NumberFormat nf2 = NumberFormat.getPercentInstance(); 18. System.out.println(nf2.format(0.55));
结果:
234234.23
34.23
2.34E0004
23423.342
55.5244%
13,423,423.234
55%
如果要将带一定格式的字符串数字转化为数字类型,则值需要调用格式对象的parse()方法即可
相关推荐
内容概要:本文详细介绍了LabVIEW控件的设计与实现,尤其是一些由经验丰富的老工程师精心打造的控件。LabVIEW是一款图形化编程语言,广泛应用于数据采集、仪器控制和工业自动化领域。文中通过具体实例展示了如何利用LabVIEW创建美观且功能强大的控件,如滑动条、波形图、金属质感旋钮、动态波形图表以及智能选项卡等。作者强调了LabVIEW控件在灵活性和美观度方面的优势,并分享了许多实用的技术细节和优化方法。 适合人群:具有一定编程基础并希望深入了解LabVIEW控件设计的开发者和技术爱好者。 使用场景及目标:适用于需要进行高效的数据展示和交互设计的应用场景,如工业控制系统、实验室设备操作界面等。目标是帮助用户掌握LabVIEW控件的高级特性,提高开发效率和用户体验。 其他说明:文章不仅提供了具体的代码示例,还探讨了控件美学背后的设计理念和技术实现,鼓励读者探索更多可能性。
Delphi 12.3控件之unidac_10.4.0_d27pro.exe
11.盛趣自闭面(还是自己太菜).txt
58面经面试过程和题目.txt
电大操作系统课后习题解答
人工智能技术与应用演讲【61页PPT】
chromedriver-mac-arm64-135.0.7049.41.zip
内容概要:本文详细介绍了QPSK(四相移键控)调制方法及其在瑞利信道和高斯白噪声信道下的误码率(BER)性能分析。首先展示了QPSK星座图的绘制方法,接着构建了一个简化的QPSK发射机模型,用于将二进制比特流映射到相应的星座点。随后,分别实现了两种信道模型:高斯白噪声信道(AWGN)和瑞利信道,并解释了它们的工作原理以及如何向传输信号添加噪声。文中还提供了详细的误码率测试脚本,通过大量随机比特进行仿真,最终得到了不同信噪比条件下的误码率曲线。此外,作者还讨论了QPSK与其他调制方式如BPSK、16QAM之间的性能差异,强调了频谱效率与抗噪能力之间的权衡关系。 适合人群:对无线通信系统感兴趣的科研人员、研究生以及从事通信工程领域的工程师。 使用场景及目标:①帮助读者理解QPSK的基本原理及其在不同信道环境中的行为特性;②提供实用的Python代码片段,便于快速搭建仿真环境并验证理论结果;③探讨各种调制方式的选择依据,指导实际应用中的优化决策。 其他说明:文中多次提到‘骚操作’,意指一些巧妙但非传统的编程技巧,有助于提高代码执行效率或简化复杂度。同时提醒读者注意仿真过程中可能出现的问题,如
新建 Microsoft Word 文档 (9).docx
计算机科学与技术- 软件开发工具 培训资料
bitcount统计每个元素中设置的位数 B = bitcount(A) Counts the number '1' bits in each element B = bitcount(A, bitValue) "bitValue" = 1 = default = counts the occurance of '1' if bitValue = 0; counts the number '0' The total bits to verify is [8,16,32,or 64] based on the maximal value of A B = bitcount(A, bitValue, maxBits) the total # of bits to examine
MOM生产运营管理平台解决方案【35页PPT】
deli-数码录音电话机-HCD6238(28)P-TSD-使用说明书
Java项目基于ssm框架的课程设计,包含LW+ppt
Delphi 12.3控件之Tsilang 7.5.0.0 D12.7z
ios+UIButton分类+UIButton+UIButton图片文字位置
项目已获导师指导并通过的高分毕业设计项目,可作为课程设计和期末大作业,下载即用无需修改,项目完整确保可以运行。 该系统功能完善、界面美观、操作简单、功能齐全、管理便捷,具有很高的实际应用价值。 项目都经过严格调试,确保可以运行!可以放心下载
Java项目基于ssm框架的课程设计,包含LW+ppt
Delphi 12.3控件之TextEditorPro64.7z
尝试给OpenHarmony4.0增加可以在动态库中使用的日志模块 文章使用的资源,防止gitee资源丢失