java tostring格式化日期_Java格式化日期的三种方式

1)借助DateFormat类:

public String toString(Date d) {

SimpleDateFormat sdf = new SimpleDateFormat(“yyyy-MM-dd HH:mm:ss”);

return sdf.format(d);

}

2)使用String.format()方法。

String.format()的用法类似于C语言的printf,C语言转JAVA的同学一定会喜欢这个方式的。

public static String toString(Date d) {

String format = “%1$tY-%1$tm-%1$td %1$tH:%1$tM:%1$tS”;

return String.format(format, d);

}

下面对格式字符串说明

“%1$tY” %表示转义,它后面的“1$tY”是格式说明,运行时会被替换掉,不会作为普通的字符输出。由于一个参数

可能会被格式化好多次,“1$”表示格式化第一个参数,“tY”表示格式化时间中的年份字段, 那么”%1$tY”输出

的值为d的年份,比如2014,同理类推:”%1$tm”输出月。

具体的格式化说明请参看java.util.Formatter类的javadoc。

3)使用Calendar自己格式化

public static String toString(Date d) {

Calendar c = Calendar.getInstance();

c.setTime(d);

int year = c.get(Calendar.YEAR);

int month = c.get(Calendar.MONTH) + 1;

int dayInMonth = c.get(Calendar.DAY_OF_MONTH);

int hour = c.get(Calendar.HOUR_OF_DAY);

int minute = c.get(Calendar.MINUTE);

int seconds = c.get(Calendar.SECOND);

String ret = String.valueOf(year);

ret += “-”;

ret += month < 10 ? “0″ + month : String.valueOf(month);

ret += “-”;

ret += dayInMonth < 10 ? “0″ + dayInMonth : String.valueOf(dayInMonth);

ret += ” “;

ret += hour < 10 ? “0″ + hour : String.valueOf(hour);

ret += “:”;

ret += minute < 10 ? “0″ + hour : String.valueOf(minute);

ret += “:”;

ret += seconds < 10 ? “0″ + hour : String.valueOf(seconds);

return ret;

}

代码很简单,不过有点重复造轮子的嫌疑。

Java中可以使用第三方库如JSqlParser和PrettySQL来格式化SQL语句。其中,JSqlParser可以将SQL语句解析成AST(抽象语法树)形式,然后再将AST转化为格式化后的SQL语句;而PrettySQL则可以直接对SQL语句进行格式化。 以下是使用JSqlParser进行SQL语句格式化的示例代码: ```java import java.io.StringReader; import net.sf.jsqlparser.parser.CCJSqlParserUtil; import net.sf.jsqlparser.statement.Statement; import net.sf.jsqlparser.util.deparser.ExpressionDeParser; import net.sf.jsqlparser.util.deparser.SelectDeParser; import net.sf.jsqlparser.util.deparser.StatementDeParser; public class SqlFormatter { public static String format(String sql) throws Exception { Statement stmt = CCJSqlParserUtil.parse(new StringReader(sql)); SelectDeParser selectDeparser = new SelectDeParser(); StatementDeParser stmtDeparser = new StatementDeParser(selectDeparser, new StringBuilder()); ExpressionDeParser expressionDeparser = new ExpressionDeParser(stmtDeparser, selectDeparser, new StringBuilder()); stmtDeparser.setExpressionVisitor(expressionDeparser); stmt.accept(stmtDeparser); return stmtDeparser.getBuffer().toString(); } } ``` 使用示例: ```java String sql = "SELECT id, name FROM users WHERE age > 18"; String formattedSql = SqlFormatter.format(sql); System.out.println(formattedSql); ``` 输出结果: ``` SELECT id, name FROM users WHERE age > 18 ``` 注:JSqlParser还可以进行更复杂的SQL语句解析和转化,如增、删、改操作,JOIN查询等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值