String format 方法【转载】

本文详细介绍了如何使用String.format()函数对整数、浮点数、字符、百分比符号及日期等进行格式化处理,提供了丰富的示例代码帮助读者快速掌握各种格式化技巧。

1.整数 进行格式化%[index$] [标识][最小宽度] 转换方式
        我们可以看到,格式化字符串由4部分组成,其中%[index$]的含义 我们上面已经讲过,[最小宽度] 的含义也很好理解,就是最终该整数转化的字符串最少包含多少位数字。我们来看看剩下2个部分的含义吧:

标识 : 
'-'    在最小宽度内左对齐,不可以与“用0填充”同时使用
'#'    只适用于8进制和16进制,8进制时在结果前面增加一个0,16进制时在结果前面增加0x
'+'    结果总是包括一个符号(一般情况下只适用于10进制,若对象为BigInteger才可以用于8进制和16进制)
'  '    正值前加空格,负值前加负号(一般情况下只适用于10进制,若对象为BigInteger才可以用于8进制和16进制)
'0'    结果将用零来填充
','    只适用于10进制,每3位数字之间用“,”分隔
'('    若参数是负数,则结果中不添加负号而是用圆括号把数字括起来(同‘+
’具有同样的限制)

转换方式
d
-十进制   o-八进制   x或X-十六进制

        上面的说明过于枯燥,我们来看几个具体的例子。需要特别注意的一点是:大部分标识字符可以同时使用

        System.out.println(String.format( " %1$,09d " - 3123 ));
        System.out.println(String.format(
" %1$9d " - 31
));
        System.out.println(String.format(
" %1$-9d " - 31
));
        System.out.println(String.format(
" %1$(9d " - 31
));
        System.out.println(String.format(
" %1$#9x " 5689
));

//
结果为:
//
-0003,123
//
      -31
//
-31      
//
     (31)
//    0x1639



2.浮点数 进行格式化 %[index$][标识] [最少宽度][.精度] 转换方式
        我们可以看到,浮点数的转换多了一个“精度”选项,可以控制小数点后面的位数。

标识 : 
'-'    在最小宽度内左对齐,不可以与“用0填充”同时使用
'+'    结果总是包括一个符号
'  '    正值前加空格,负值前加负号
'0'    结果将用零来填充
','    每3位数字之间用“,”分隔(只适用于fgG的转换)
'('
    若参数是负数,则结果中不添加负号而是用圆括号把数字括起来(只适用于eEfgG的转换)

转换方式
'e', 'E'  --  结果被格式化为用计算机科学记数法表示的十进制数
'f'          --  结果被格式化为十进制普通表示方式
'g', 'G'    --  根据具体情况,自动选择用普通表示方式还是科学计数法方式
'a', 'A'    --   结果被格式化为带有效位数和指数的十六进制浮点数



3.字符 进行格式化
        对字符进行格式化是非常简单的,c表示字符,标识中'-'表示左对齐,其他就没什么了。

4.百分比符号 进行格式化
       
看了上面的说明,大家会发现百分比符号“%”是特殊格式的一个前缀。那么我们要输入一个百分比符号该怎么办呢?肯定是需要转义字符的,但是要注意的是,在这里转义字符不是“\”,而是“%”。换句话说,下面这条语句可以输出一个“12%”:
System.out.println(String.format("%1$d%%", 12));

5.取得平台独立的行分隔符
        System.getProperty("line.separator")可以取得平台独立的行分隔符,但是用在format中间未免显得过于烦琐了。于是format函数自带了一个平台独立的行分隔符那就是
String.format("%n")。

6.日期类型 进行格式化
         以下日期和时间转换的后缀字符是为 't' 和 'T' 转换定义的。这些类型相似于但不完全等同于那些由 GNU date 和 POSIX strftime(3c) 定义的类型。提供其他转换类型是为了访问特定于 Java 的功能(如将 'L' 用作秒中的毫秒)。

以下转换字符用来格式化时间:

'H'     24 小时制的小时,被格式化为必要时带前导零的两位数,即 00 - 23。
'I'     12 小时制的小时,被格式化为必要时带前导零的两位数,即 01 - 12。
'k'     24 小时制的小时,即 0 - 23。
'l'     12 小时制的小时,即 1 - 12。
'M'     小时中的分钟,被格式化为必要时带前导零的两位数,即 00 - 59。
'S'     分钟中的秒,被格式化为必要时带前导零的两位数,即 00 - 60 ("60" 是支持闰秒所需的一个特殊值)。
'L'     秒中的毫秒,被格式化为必要时带前导零的三位数,即 000 - 999。
'N'     秒中的毫微秒,被格式化为必要时带前导零的九位数,即 000000000 - 999999999。
'p'     特定于语言环境的 上午或下午 标记以小写形式表示,例如 "am" 或 "pm"。使用转换前缀 'T' 可以强行将此输出转换为大写形式。
'z'     相对于 GMT 的 RFC 822 格式的数字时区偏移量,例如 -0800。
'Z'     表示时区缩写形式的字符串。Formatter 的语言环境将取代参数的语言环境(如果有)。
's'     自协调世界时 (UTC) 1970 年 1 月 1 日 00:00:00 至现在所经过的秒数,即 Long.MIN_VALUE/1000 与 Long.MAX_VALUE/1000 之间的差值。
'Q'     自协调世界时 (UTC) 1970 年 1 月 1 日 00:00:00 至现在所经过的毫秒数,即 Long.MIN_VALUE 与 Long.MAX_VALUE 之间的差值。

以下转换字符用来格式化日期:
'B'     特定于语言环境的月份全称,例如 "January" 和 "February"。
'b'     特定于语言环境的月份简称,例如 "Jan" 和 "Feb"。
'h'     与 'b' 相同。
'A'     特定于语言环境的星期几全称,例如 "Sunday" 和 "Monday"
'a'     特定于语言环境的星期几简称,例如 "Sun" 和 "Mon"
'C'     除以 100 的四位数表示的年份,被格式化为必要时带前导零的两位数,即 00 - 99
'Y'     年份,被格式化为必要时带前导零的四位数(至少),例如,0092 等于格里高利历的 92 CE。
'y'     年份的最后两位数,被格式化为必要时带前导零的两位数,即 00 - 99。
'j'     一年中的天数,被格式化为必要时带前导零的三位数,例如,对于格里高利历是 001 - 366。
'm'     月份,被格式化为必要时带前导零的两位数,即 01 - 13。
'd'     一个月中的天数,被格式化为必要时带前导零两位数,即 01 - 31
'e'     一个月中的天数,被格式化为两位数,即 1 - 31。

以下转换字符用于格式化常见的日期/时间组合。
'R'     24 小时制的时间,被格式化为 "%tH:%tM"
'T'     24 小时制的时间,被格式化为 "%tH:%tM:%tS"。
'r'     12 小时制的时间,被格式化为 "%tI:%tM:%tS %Tp"。上午或下午标记 ('%Tp') 的位置可能与语言环境有关。
'D'     日期,被格式化为 "%tm/%td/%ty"。
'F'     ISO 8601 格式的完整日期,被格式化为 "%tY-%tm-%td"。
'c'     日期和时间,被格式化为 "%ta %tb %td %tT %tZ %tY",例如 "Sun Jul 20 16:17:00 EDT 1969"。

1.mapper package myPageRank; import org.apache.hadoop.io.IntWritable; import org.apache.hadoop.io.Text; import org.apache.hadoop.mapreduce.Mapper; import java.io.IOException; import java.util.StringTokenizer; /** * @author tulie * @ceerte $(YEAR)-$(MONTH)-$(DAY)-$(TIME) */ public class PRMapper extends Mapper<Object, Text, IntWritable, Text> { private IntWritable id; private String pr; private int count; private float average_pr; //重写map方法 public void map(Object key, Text value, Context context) { //构造一个用来解析 str 的 StringTokenizer 对象。java 默认的分隔符是空格("")、制表符(\t)、换行符(\n)、回车符(\r)。 StringTokenizer str = new StringTokenizer(value.toString()); //|1 6 2 4 5 if(str.hasMoreTokens())//返回是否还有分隔符 { id = new IntWritable(Integer.parseInt(str.nextToken()));//1 |6 2 4 5 }else{ return; } pr = str.nextToken();//返回从当前位置到下一个分隔符的字符串 1 6 |2 4 5 count = str.countTokens();//3 average_pr = Float.parseFloat(pr)/count; while(str.hasMoreTokens()) { try{ String nextId = str.nextToken();//1 6 2| 4 5 IntWritable linid = new IntWritable(Integer.parseInt(nextId)); //将网页向外链接的ID以“pr+得到贡献值”格式输出 Text avpr = new Text("pr" + average_pr); context.write(linid, avpr); // 将网页ID和PR值输出 Text ids = new Text("id" + nextId); context.write(id, ids); }catch(IOException e) { e.printStackTrace(); }catch (InterruptedException e) { e.printStackTrace(); } } } } AI写代码 java 运行 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 收起代码块 2.reducer import org.apache.hadoop.io.IntWritable; import org.apache.hadoop.io.Text; import org.apache.hadoop.mapreduce.Reducer; import java.io.IOException; import java.util.ArrayList; /** * @author tulie * @ceerte $(YEAR)-$(MONTH)-$(DAY)-$(TIME) */ public class PRReducer extends Reducer<IntWritable, Text, IntWritable, Text> { //重写reduce方法 public void reduce(IntWritable key, Iterable<Text> values, Context context) { // 定义一个存储网页链接ID的队列 ArrayList<String> ids = new ArrayList<String>(); // 将所有的链接ID以String格式保存 String strid = " "; // 定义一个保存网页PR值的变量 float pr = 0; //遍历 System.out.println(key.get()); for(Text txt : values) { String str = txt.toString(); //判断value是贡献值还是向外部的链接 if (str.startsWith("pr")) { // 贡献值 pr += Float.parseFloat(str.substring(2)); System.out.println(pr); } else if (str.startsWith("id")) { // 链接id String id = str.substring(2); ids.add(id); } } pr = 0.85f*pr + 0.15f; // 得到所有链接ID的String形式 for (int i = 0; i < ids.size(); i++) { strid += ids.get(i) + " "; } // 组合pr+lianjie成原文件的格式类型 String strpr = String.format("%.5f", pr); String result = strpr + strid; try { context.write(key, new Text(result)); } catch (IOException e) { e.printStackTrace(); } catch (InterruptedException e) { e.printStackTrace(); } } } AI写代码 java 运行 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 3.Driver import org.apache.hadoop.conf.Configuration; import org.apache.hadoop.fs.Path; import org.apache.hadoop.io.IntWritable; import org.apache.hadoop.io.Text; import org.apache.hadoop.mapred.lib.ChainMapper; import org.apache.hadoop.mapreduce.Job; import org.apache.hadoop.mapreduce.lib.input.FileInputFormat; import org.apache.hadoop.mapreduce.lib.output.FileOutputFormat; /** * @author tulie * @ceerte $(YEAR)-$(MONTH)-$(DAY)-$(TIME) */ AI写代码 java 运行 1 2 3 4 5 6 7 8 9 10 11 12 13 14 public class PRDriver { public static void main(String[] args) throws Exception{ Configuration conf = new Configuration(); String pathIn1 = “D:/PageRank/input/input.txt”; String pathOut=“D:/PageRank/output1/PageRankOutput0”; for(int i=1;i<41;i++){ //加入for循环 Job job = Job.getInstance(conf, “MapReduce pagerank”); job.setJarByClass(PRDriver.class); job.setMapperClass(PRMapper.class); job.setReducerClass(PRReducer.class); job.setOutputKeyClass(IntWritable.class); job.setOutputValueClass(Text.class); FileInputFormat.addInputPath(job, new Path(pathIn1)); FileOutputFormat.setOutputPath(job, new Path(pathOut)); pathIn1 = pathOut;//把输出的地址改成下一次迭代的输入地址 pathOut = pathOut+i;//把下一次的输出设置成一个新地址。 job.waitForCompletion(true);//把System.exit()去掉 } } ———————————————— 版权声明:本文为优快云博主「图列」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。 原文链接:https://blog.youkuaiyun.com/TulieCS/article/details/108483363(生成一个完整的)
最新发布
10-22
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值