Java字符串_日期_数字格式化输出

来源:互联网 发布:易语言源码下载 编辑:程序博客网 时间:2024/05/16 10:35

   在C中可以使用类似printf(“%d %8.2f\\n”, 1001, 52.335)的方法实现格式化输出,可是Java中的System.out.println()并没有对应的功能。要格式化输出,必须使用java.text包中的类来实现类似的操作(要不怎么体现面向对象的优越性呢,不过据说jdk1.5准备又补上)。当然了,java.text包的功能还是很强大的,奇怪的是很多书中都没有涉及,而一般谁又有工夫整天去看API?

    注意:由于这里说得很简略,因此请参照下面的Demo程序。

    格式化数字

    在NumberFormat类中为我们提供了格式化4种数字的方法:整数、小数、货币和百分比,通过工厂方法getNumberInstance, getNumberIntance, getCurrencyInstance, getPercentInstance方法获得相应的实例对象就行。例如我们要以字符串表示人民币88888.88元,这样来写就行:

    NumberFormat nf = NumberFormat.getCurrencyInstance();

    System.out.println(nf.format(88888.88));

    定制格式化数字

    可是对于稍微复杂一点的需求,NumberFormat就满足不了了,幸好java还提供了DecimalFormat实现定制的格式化。要使用DecimalFormat对象,必须提供给它提供一个格式化的模式(pattern):

    String pattern = …

    DecimalFormat df = new DecimalFormat(pattern);

    或者:

    DecimalFormat df = new DecimalFormat();

    df. applyPattern(pattern);

    然后就调用它的format方法就行了。

    所以关键就是这个模式怎么定义。在DecimalFormat类的JavaDoc中有模式的语法表示,不过很难说清楚(是我说不清楚,呵呵),请看看Demo自己多试试吧。下面是模式中某些字符的含义表:

    字符
     含义

    0
     一位数字,这一位缺失显示为0。用来补零

    #
     一位数字, 这一位缺失就不显示

    .
     小数点,不用多说了吧

    ,
     千位分隔符

    E
     科学计数法

    %
     百分比

 


    格式化日期

    把日期转化为字符串最简单的方法就是调用Date类的toString或者toLocaleString方法:

    System.out.println(new Date());

    输出:2004-8-7 8:16:14。可是如果我们想把月和日补成2位不要时分秒2004-08-07,这就不灵了。java.text.DateFormat提供了大量的工厂方法:getDateInstance(int style), getTimeInstance(int style), getDateTimeInstance(int dateStyle, int timeStyle)等等。其中style必须是DateFormat.LONG, DateFormat.MEDIUM, DateFormat.SHORT之一。Demo中的defaultDateFormat方法作了一个简单的实验。

 

    定制格式化日期:

    同样,java.text.SimpleDateFormat可以通过模式(pattern)实现定制格式化:

    String pattern = …

    SimpleDateFormat df = new SimpleDateFormat(pattern);

    或者:

    SimpleDateFormat df = new SimpleDateFormat();

    df. applyPattern(pattern);

    下面是SimpleDateFormat的javadoc中的一个模式符号简表:

    符号
     意义
     合法数值
     示例

    y
     Year
     Year
     1996; 96

    M
     Month in year
     Month
     July; Jul; 07

    d  [Page]
     Day in month
     Number
     10

    a
     Am/pm marker
     Text
     PM

    H
     Hour in day (0-23)
     Number
     0

    h
     Hour in am/pm (1-12)
     Number
     12

    m
     Minute in hour
     Number
     30

    s
     Second in minute
     Number
     55

    S
     Millisecond
     Number
     978

    z
     Time zone
     General time zone
     Pacific Standard Time; PST; GMT-08:00

    Z
     Time zone
     RFC 822 time zone
     -0800


    注意的是,符号的大小写意义是不同的,符号的个数也会导致输出不一样。例如用MM就会把1月份显示成01,而用M则不会补零。对于年份,两个yy会只输出两位年份,yyyy则会输出4位年份。

    实际上,上面的类还提供了很多其他方法,特别是用于本地化(Locale)定制格式化的方法,以及从字符串表示转化为相应对象的parse方法,还有把格式化结果附加到一个StringBuffer的方法(应该是用来提高性能)。

    最后是一个小Demo和输出结果:

    TestFormat.java:

    import java.text.*;

    import java.util.*;

    public class TestFormat {

        public static void main(String[] args) {

           defaultNumberFormat();

           System.out.println();

     customNumberFormat();

       System.out.println();

 

       defaultDateFormat();

       System.out.println();

 

       customDateFormat();

       System.out.println();

 

    }

 

    public static void defaultNumberFormat() {

       int i = 123456;

       double x = 882323.23523;

       double p = 0.528;

       double c = 52.83; [Page]

 

       NumberFormat nf = NumberFormat.getInstance();

       System.out.println(\"Integer \" + i + \" is displayed as \" + nf.format(i));

       System.out.println(\"Double \" + x + \" is displayed as \" + nf.format(x));

 

       NumberFormat nfInt = NumberFormat.getIntegerInstance();

       System.out.println(\"Integer \" + i + \" is displayed as \" + nfInt.format(i));

 

       NumberFormat nfNumber = NumberFormat.getNumberInstance();

       System.out.println(\"Double \" + x + \" is displayed as \" + nfNumber.format(x));

 

       NumberFormat nfPercent = NumberFormat.getPercentInstance();

       System.out.println(\"Percent \" + p + \" is displayed as \" + nfPercent.format(p));

 

       NumberFormat nfCurrency = NumberFormat.getCurrencyInstance();

       System.out.println(\"Currency \" + p + \" is displayed as \" + nfCurrency.format(c));

 

       //这里没有涉及相应的parse方法

    }

 

    public static void customNumberFormat() {

       double x = 1000.0 / 3;

       System.out.println(\"default output is \" + x);

       patternPrint(\"###,###.##\", x);

       patternPrint(\"####.##\", x);

       patternPrint(\"####.00\", x);

       patternPrint(\"####.0#\", x); [Page]

       patternPrint(\"00000.##\", x);

       patternPrint(\"$###,###.##\", x);

        patternPrint(\"0.###E0\", x);

       patternPrint(\"00.##%\", x);

 

       double y = 23.0012;

       System.out.println(\"default output is \" + y);

       patternPrint(\"###,###.##\", y);

       patternPrint(\"####.##\", y);

       patternPrint(\"####.00\", y);

       patternPrint(\"####.0#\", y);

       patternPrint(\"00000.##\", y);

       patternPrint(\"$###,###.##\", y);

       patternPrint(\"0.###E0\", y);

       patternPrint(\"00.##%\", y);

 

        }

 

        public static void patternPrint(String pattern, double x) {

           DecimalFormat df = new DecimalFormat(pattern);

           System.out.println(\"output for pattern \" + pattern + \" is \" + df.format(x));

        }

 

        public static void defaultDateFormat(){

           Date date = new Date();

 

           System.out.println(\"simple date \" + date.toLocaleString());

 

           DateFormat df = DateFormat.getDateTimeInstance();

           System.out.println(df.format(date));

 

           DateFormat dfLong = DateFormat.getDateTimeInstance(DateFormat.LONG, DateFormat.LONG);

           System.out.println(dfLong.format(date));

 

           DateFormat dfMedium = DateFormat.getDateTimeInstance(DateFormat.MEDIUM,  [Page]

               DateFormat.MEDIUM);

           System.out.println(dfMedium.format(date));

 

           DateFormat dfShort = DateFormat.getDateTimeInstance(DateFormat.SHORT, DateFormat.SHORT);

           System.out.println(dfShort.format(date));

        }

 

        public static void customDateFormat() {

           Date date = new Date();

           patternPrint(\"yyyy.MM.dd HH:mm:ss z\", date);  //两个MM, dd会导致补零

           patternPrint(\"yy年M月d日 HH时mm分\", date);  //两个yy就显示为两位年份

           patternPrint(\"EEE, MMM d, ’’yy\", date);

           patternPrint(\"h:mm a\", date);

           patternPrint(\"hh ’o’’clock’ a, zzzz\", date);

           patternPrint(\"yyyyy.MMMMM.dd GGG hh:mm aaa\", date);

           patternPrint(\"EEE, d MMM yyyy HH:mm:ss Z\", date);

           patternPrint(\"yyMMddHHmmssZ\", date);

        }

 

        public static void patternPrint(String pattern, Date date){

           SimpleDateFormat df = new SimpleDateFormat(pattern);

           System.out.println(df.format(date));

        }

    }

 

    输出:

    Integer 123456 is displayed as 123,456

    Double 882323.23523 is displayed as 882,323.235

    Integer 123456 is displayed as 123,456

    Double 882323.23523 is displayed as 882,323.235

    Percent 0.528 is displayed as 53%

    Currency 0.528 is displayed as ¥52.83

 

    default output is 333.3333333333333

    output for pattern ###,###.## is 333.33

    output for pattern ####.## is 333.33 [Page]

    output for pattern ####.00 is 333.33

    output for pattern ####.0# is 333.33

    output for pattern 00000.## is 00333.33

    output for pattern $###,###.## is $333.33

    output for pattern 0.###E0 is 3.333E2

    output for pattern 00.##% is 33333.33%

    default output is 23.0012

    output for pattern ###,###.## is 23

    output for pattern ####.## is 23

    output for pattern ####.00 is 23.00

 

output for pattern ####.0# is 23.0

    output for pattern 00000.## is 00023

    output for pattern $###,###.## is $23

    output for pattern 0.###E0 is 2.3E1

    output for pattern 00.##% is 2300.12%

 

    simple date 2004-8-7 8:16:14

    2004-8-7 8:16:14

    2004年8月7日 上午08时16分14秒

    2004-8-7 8:16:14

    04-8-7 上午8:16

 

    2004.08.07 08:16:14 GMT+08:00

    04年8月7日 08时16分

    星期六, 八月 7, ’04

    8:16 上午

    08 o’clock 上午, GMT+08:00

    02004.八月.07 公元 08:16 上午

    星期六, 7 八月 2004 08:16:14 +0800

    040807081614+0800

 

从Java中往数据库(Oracle,msSql等..)插入Date类型数据
分类: Java 2012-04-01 23:18 215人阅读 评论(1) 收藏 举报
第一步:建表[sql] view plaincopyprint?
--建表  
create table tempDate( 
       id number primary key not null, 
       now date 
); 
 
--插入测试数据  
insert into tempDate values(1,to_date(To_char(sysdate, 'yyyy-mm-dd'),'yyyy-mm-dd')); 
 
--提交数据  
commit; 
 
--查询tempDte表中的数据  
select * from tempDate; 
  

--建表
create table tempDate(
       id number primary key not null,
       now date
);

--插入测试数据
insert into tempDate values(1,to_date(To_char(sysdate, 'yyyy-mm-dd'),'yyyy-mm-dd'));

--提交数据
commit;

--查询tempDte表中的数据
select * from tempDate;
 


查询数据得到结果:

 

 


第二步:在MyElipse中建立测试Java项目

  比如说要插入当前时间,代码如下:

 

 

[java] view plaincopyprint?
import java.sql.Connection; 
import java.sql.DriverManager; 
import java.sql.PreparedStatement; 
import java.sql.SQLException; 
import java.text.SimpleDateFormat; 
import java.util.Date; 
 
public class test { 
    public static void main(String[] args) { 
        Connection conn = null; 
        PreparedStatement ps = null; 
        try { 
            Class.forName("oracle.jdbc.OracleDriver");// 注册驱动  
            conn = DriverManager.getConnection( 
                    "jdbc:oracle:thin:@localhost:1521:orcl", "scott", 
                    "binxinai11");// 得到连接  
            String now = new SimpleDateFormat("yyyy-MM-dd").format(new Date());// 得到当前日期的字符串形式  
            String sql = "insert into tempDate values(3,To_date('" + now 
                    + "','yyyy-mm-dd'))";// 创建sql语句  
            ps = conn.prepareStatement(sql);// 在内存中准备向oracle发送sql语句  
            if (ps.executeUpdate() == 1) {// 执行插入判断返回结果  
                System.out.println("insert Ok"); 
            } 
        } catch (ClassNotFoundException e) { 
            // TODO Auto-generated catch block  
            e.printStackTrace(); 
        } catch (SQLException e) { 
            // TODO Auto-generated catch block  
            e.printStackTrace(); 
        } 
    }