java小技巧
String 转 Date
String classCode = RequestHandler.getString(request, "classCode");
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-mm-dd hh:mm:ss");
DicClassInfo classInfo=new DicClassInfo();
classInfo.setStartDate(sdf.parse(startDate));
int型除法保留两位小数/求百分比
int openCount = temp.getIsOpenCount();
int passCount = temp.getIsPassCount();
double k = (double)passCount/openCount*100;
java.math.BigDecimal big = new java.math.BigDecimal(k);
String l =big.setScale(2,java.math.BigDecimal.ROUND_HALF_UP).doubleValue() +"%";
float保留两位小数
//1
float f = 34.232323;
BigDecimal b = new BigDecimal(f);
float f1 = b.setScale(2, BigDecimal.ROUND_HALF_UP).floatValue();
// b.setScale(2, BigDecimal.ROUND_HALF_UP) 表明四舍五入,保留两位小数 //2
float scale = 34.236323;
DecimalFormat fnum = new DecimalFormat("##0.00");
String dd=fnum.format(scale);
System.out.println(dd); //3
float a = 123.2334f;
float b = (float)(Math.round(a*100))/100;
BigDecimal保留两位小数
//金额保留小数后两位
BigDecimal b = invoiceTemp.getInvoicePrice();
BigDecimal setScale = b.setScale(2,BigDecimal.ROUND_DOWN);
invoiceTemp.setInvoicePrice(setScale);
参数定义
ROUND_CEILING 向正无穷方向舍入
ROUND_DOWN 向零方向舍入
ROUND_FLOOR 向负无穷方向舍入
ROUND_HALF_DOWN 向(距离)最近的一边舍入,除非两边(的距离)是相等,如果是这样,向下舍入, 例如1.55 保留一位小数结果为1.5
ROUND_HALF_EVEN 向(距离)最近的一边舍入,除非两边(的距离)是相等,如果是这样,如果保留位数是奇数,使用ROUND_HALF_UP
,如果是偶数,使用ROUND_HALF_DOWN
ROUND_HALF_UP 向(距离)最近的一边舍入,除非两边(的距离)是相等,如果是这样,向上舍入,
1.55保留一位小数结果为1.6
ROUND_UNNECESSARY 计算结果是精确的,不需要舍入模式
ROUND_UP 向远离0的方向舍入
Action文件mapping.findForward()动态传参至Struts-config.xml
//后台方法
return mapping.findForward(outSystemSign); //配置文件无需判断,直接接收,直接写明映射内容即可
<forward name="qgtzsbcjh" path="/WEB-INF/jsp/outsystem/kpflowchart/qgtzsbcjh.jsp"/>
<forward name="gusuwx" path="/WEB-INF/jsp/outsystem/kpflowchart/gusuwx.jsp"/>
isBlank、isEmpty、isNull
org.apache.commons.lang.StringUtils类提供了String的常用操作,最常用判空如下
- StringUtils.isEmpty(String str)
//判断某字符串是否为空,标准是 str==null 或 str.length()==0
System.out.println(StringUtils.isEmpty(null)); //true
System.out.println(StringUtils.isEmpty("")); //true
System.out.println(StringUtils.isEmpty(" ")); //false
System.out.println(StringUtils.isEmpty("dd")); //false
- StringUtils.isNotEmpty(String str) 等价于 !isEmpty(String str),判断是否不为空也不为null,在要替换字段为空串时,应使用isNotNull,isNotEmpty会自动跳过
- StringUtils.isBlank(String str),StringUtils.isNotBlank(String str) 等价于 !isBlank(String str)
//判断某字符串是否为空或长度为0或由空白符(whitespace) 构成System.out.println(StringUtils.isBlank(null)); //true
System.out.println(StringUtils.isBlank("")); //true
System.out.println(StringUtils.isBlank(" ")); //true
System.out.println(StringUtils.isBlank("dd")); //false
时间段控制(00:00:00—23:59:59)
if(null!=startDate){
int len = startDate.length();
switch(len){
case(10):startDate = startDate + " 00:00:00.000";break;
case(19):startDate = startDate + ".000";break;
default:if(len>10){startDate = startDate.substring(0,10)+"00:00:00.000";}break;
}
}
if(null!=endDate){
int len = endDate.length();
switch(len){
case(10):endDate = endDate + " 23:59:59.999";break;
case(19):startDate = startDate + ".999";break;
default:if(len>10){startDate = startDate.substring(0,10)+"23:59:59.999";}break;
}
}
计算时间差
String date = "2010-01-01 11:11:11";
SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); String nowDate = df.format(new Date());
Date d1 = df.parse(date);
Date d2 = df.parse(nowDate);
long between = (d2.getTime() - d1.getTime())/1000; //时间差(秒)
获取指定时间
//当前月第一天
Calendar c = Calendar.getInstance();
c.setTime(new Date());
c.set(5, 1);
Date startMonthDate =c.getTime();
String startMonthStr = dateToString(startMonthDate , "yyyy-MM-dd 00:00:00"); //当前月最后一天
Calendar calendar = Calendar.getInstance();
calendar.setTime(startMonthDate );
calendar.add(2, n);
Date endMonthDate=calendar .getTime();
String endMonthStr = dateToString(endMonthDate, "yyyy-MM-dd 00:00:00"); //七天前
Calendar calendar = Calendar.getInstance();
calendar.set(Calendar.DAY_OF_YEAR, calendar.get(Calendar.DAY_OF_YEAR) - 7);
Date earlySevenDate = calendar.getTime();
String earlySevenStr = dateToString(earlySevenDate, "yyyy-MM-dd 00:00:00"); //当天
String todayStr = dateToString(new Date(), "yyyy-MM-dd 00:00:00"); //Date date, int n date时间加n天
Calendar calendar = Calendar.getInstance();
calendar.setTime(date);
calendar.add(5, n);
Date nDayLaterDate = calendar.getTime();
String earlySevenStr = dateToString(nDayLaterDate, "yyyy-MM-dd 00:00:00"); //Date date, int n date时间加n月
Calendar calendar = Calendar.getInstance();
calendar.setTime(date);
calendar.add(2, n);
Date nMonthLaterDate = calendar.getTime();
String earlySevenStr = dateToString(nMonthLaterDate, "yyyy-MM-dd 00:00:00"); public static String dateToString(Date date, String pattern) {
if (date != null) {
SimpleDateFormat sdf = new SimpleDateFormat(pattern);
return sdf.format(date);
} else {
return "";
}
} //Calendar的add()方法:1是对年份操作,2是对月份操作,3是对星期操作,5是对日期操作,11是对小时操作,12是对分钟操作,13是对秒操作,14是对毫秒操作。
String数组、List转换
// List转String数组
List<String> list = new ArrayList<String>();
list.add("a1");
list.add("a2");
String[] toBeStored = list.toArray(new String[list.size()]); for(String s : toBeStored) {
System.out.println(s);
} //String数组转List
String[] arr = new String[] {"1", "2"};
List<String> list = Arrays.asList(arr);
excel导出合并单元格(行)、设置样式
<%@page import="org.apache.poi.hssf.util.Region"%>
<%@page import="org.apache.poi.hssf.usermodel.HSSFFont"%>
<%@page import="org.apache.poi.hssf.util.HSSFColor"%> HSSFCellStyle cellStyle = wb.createCellStyle();//新样式//居中
cellStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER); //居中
HSSFFont font=wb.createFont();
font.setColor(HSSFColor.RED.index);//字体颜色
font.setFontHeightInPoints((short)12);
font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);//字体增粗
cellStyle.setFont(font);//把字体应用到当前的样式
cell.setCellStyle(cellStyle);
//合并第(0,0)单元格到第(0,13)单元格
sheet.addMergedRegion(new Region(0, (short)0, 0, (short)13));
if(0 != total){
cell.setCellValue("支付金额合计 : "+total+"元");
}
excel动态合并单元格(列)
short num = 1; //列
String s = "";
//sheet.getLastRowNum()获取总行数
for (int k = 1; k <= sheet.getLastRowNum(); k++) {
HSSFRow rows = sheet.getRow(k);
HSSFCell cells = rows.getCell((short)2);
if (cells.getStringCellValue().equals(s)) {
sheet.addMergedRegion(new Region(num,(short)2,k,(short)2));
HSSFRow rowsV = sheet.getRow(k);
HSSFCell cellsV = rows.getCell((short)2);
cellsV.setCellStyle(style);
} else {
num =(short) k;
}
s = cells.getStringCellValue();
}
java小技巧的更多相关文章
- Java 小技巧和在Java避免NullPonintException的最佳方法(翻译)
前几天就g+里面看到有人引用这篇博文.看了一下.受益颇多. 所以翻译过来,希望和大家一起学习.本人英语水平有限,假设有错,请大家指正. 原文地址(须要翻墙):http://ja ...
- Java小技巧输出26个英文字母
相信有的童鞋写到过与字母有关的小东西,是否有写过全部的字母呢?26个这么多字母,一个个打会疯掉.所有咱们可以用一个小技巧使用for循环帮我们把26个字母自动搞出来,大家来瞅一眼把! 使用Java遍历2 ...
- java小技巧-生成重复的字符
今天碰到个需求,根据字段个数,动态生成sql的占位符,如下: public static void main(String[] args) { System.out.println(String.jo ...
- java小技巧:如何分批次导入大量数据
//List 需要导入的数据int count = 1000;//每批次导入的数目int Lastindex = count;List<List<T>> shareList = ...
- Java小技巧:怎么循环日期?
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");try{//起始日期Date start = sdf.parse ...
- Java在处理大数据的时候一些小技巧
Java在处理大数据的时候一些小技巧 发布时间:2013-05-09 00:00:00 来源:中国IT实验室 作者:佚名 关键字:Java 众所周知,java在处理数据量比较大的时候,加载到内存必 ...
- Java内存管理的9个小技巧
Java内存管理的9个小技巧很多人都说“Java完了,只等着衰亡吧!”,为什么呢?最简单的的例子就是Java做的系统时非常占内存!一听到这样的话,一定会有不少人站出来为Java辩护,并举出一堆的性能测 ...
- java.text.MessageFormat格式化字符串时的小技巧
java.text.MessageFormat格式化字符串时的小技巧 public static void main(String[] args) throws InterruptedExceptio ...
- 关于Java内存管理的几个小技巧
这里将介绍几则Java内存管理的小技巧,让你让你从Java入门开始告别陋习,为Java程序提速.有不少人都说"Java完了,只等着衰亡吧!",为什么呢?最简单的的例子就是Java做 ...
随机推荐
- JavaSwing 船只停靠管理可视化(二)
JavaSwing 船只停靠管理可视化(一) JavaSwing 船只停靠管理可视化(二) JavaSwing 船只停靠管理可视化(三) JavaSwing 船只停靠管理可视化(四) JavaSwin ...
- Python 字符串操作分类
应用举例: str="abc defghi jklm nopqrstuvwxyz" print(str.isspace()) 运行结果: False 1) 判断类型 方法 | 说明 ...
- 关于git的一些零碎知识
git文件的三个状态:已修改,已暂存,已提交git的三个区域: 工作区,暂存区,对象库 git的几个指针(以master为例) 远程有个master,本地有个master,本地有个指针是指向远程的ma ...
- 分享一个的c++写的,模仿awk的框架类CAwkDoc
这是我好多年前,模仿awk写的. awk大家都比较熟悉,使用awk处理文件,读取文件,分割字段这些工作awk自己帮你实现了. 程序员只要编写业务逻辑代码,并且awk还提供了很多常用的字符串操作函数,可 ...
- WPF + RDLC + 动态生成列 + 表头合并
如下,评论超过20条,马上发代码*(੭*ˊᵕˋ)੭*ଘ,效果如下: 代码逻辑简单. WPF使用RDLC需要使用如下DLL 新建WPF 窗体,黏贴下大概如下 <Window xmlns:rv=&q ...
- 记一次Goroutine与wg导致的问题
前言 今天发现了一个问题是之前一直没有注意到的,这里记一下 正文 Send Closed Chan 问题概述 代码逻辑是启动时启动多个 channel, channel1 获取数据监听数据处理后发送给 ...
- 有了链路日志增强,排查Bug小意思啦!
在工作中,相信大家最怕的一件事就是听到有人在工作群艾特你:某某功能报错啦... 然后你就得屁颠屁颠的去服务器看日志,日志量少还好点,多的话找起来太麻烦了.不太容易直接定位到关键地方. 东找找西找找,好 ...
- Java 在windows中配置Maven环境和阿里云镜像
目录 1. 下载Maven 2. 配置环境变量 3. 配置镜像 4. 配置本地仓库 1. 下载Maven 官网:https://maven.apache.org/ 下载:apache-maven-3. ...
- 【Spring】IoC概述
Spring框架的核心概念--IoC IoC IoC是Inversion of Control的简写,翻译成汉语就是"控制反转".IoC并不是一门技术,而是一种设计思想,在Spri ...
- C语言目的概念(C语言学习笔记)
什么是目 目是针对操作符来说的,一个操作符影响两个操作数就表示该操作符为双目运算符 举个例子: 1+2 这里的加号影响了1和2两个操作数,所以"+"就是双目运算符 +1,-1 这里 ...