pio讀取 Excel中 電話號碼和身份證的問題

一直採用 修改Excel列爲文本的方法來支持,讀取電話號碼 和身份證號,今天解決。

 

private static String GetCellString(HSSFCell cell) {
  String strRe = "";
  try {
   int iCellType = cell.getCellType();

   switch (iCellType) {
   case HSSFCell.CELL_TYPE_NUMERIC: {
    boolean b = HSSFDateUtil.isCellDateFormatted(cell);
    if (b) {
     cell.getDateCellValue();
     String strDate = DateUtils
       .formatDate(cell.getDateCellValue(),
         DateUtils.DEFAULT_DATE_PATTERN);
     System.out.println("日期輸出" + strDate);
     return strDate;
    }
    double db = cell.getNumericCellValue();
    if (db == 0) {
     strRe = "0";
    }

 

//此處就是採用DecimalFormat 格式化的方式來解決的。
    java.text.DecimalFormat   formatter   =   new   java.text.DecimalFormat("###########");  
    strRe   =   formatter.format(cell.getNumericCellValue());  
    break;
   }

   case HSSFCell.CELL_TYPE_STRING:
    strRe = cell.getStringCellValue();
    break;
   case HSSFCell.CELL_TYPE_BLANK:
   default:
    break;
   }
   return strRe;

  } catch (Exception e) {
   e.printStackTrace();
  }
  return strRe;
 }

 

 

以下內容轉自

http://blog.csdn.net/kjfcpua/archive/2009/06/03/4240486.aspx

 

 

DecimalFormat的主要功能:

DecimalFormat 是 NumberFormat 的一個具體子類,用於格式化十進制數字。該類設計有各種功能,使其能夠分析和格式化任意語言環境中的數,包括對西方語言、阿拉伯語和印度語數字的支持。它還支持不同類型的數,包括整數 (123)、定點數 (123.4)、科學記數法表示的數 (1.23E4)、百分數 (12%) 和金額 ($123)。所有這些內容都可以本地化。

DecimalFormat 包含一個模式 和一組符號

符號含義:

 0      一個數字

 #      一個數字,不包括 0

 .      小數的分隔符的佔位符

 ,      分組分隔符的佔位符

 ;      分隔格式。

 -      缺省負數前綴。

 %      乘以 100 和作爲百分比顯示

 ?      乘以 1000 和作爲千進制貨幣符顯示;用貨幣符號代替;如果雙寫,用

         國際貨幣符號代替。如果出現在一個模式中,用貨幣十進制分隔符代

         替十進制分隔符。

 X      前綴或後綴中使用的任何其它字符,用來引用前綴或後綴中的特殊字符。

例子:

DecimalFormat df1 = new DecimalFormat("0.0");

        DecimalFormat df2 = new DecimalFormat("#.#");

        DecimalFormat df3 = new DecimalFormat("000.000");

        DecimalFormat df4 = new DecimalFormat("###.###");

       

        System.out.println(df1.format(12.34));

        System.out.println(df2.format(12.34));

        System.out.println(df3.format(12.34));

        System.out.println(df4.format(12.34));

結果:

12.3

12.3

012.340

12.34

DecimalFormat format = new DecimalFormat("###,####.000");

       System.out.println(format.format(111111123456.1227222));

      

       Locale.setDefault(Locale.US);

       DecimalFormat usFormat = new DecimalFormat("###,###.000");

       System.out.println(usFormat.format(111111123456.1227222));

      

       DecimalFormat addPattenFormat = new DecimalFormat();

       addPattenFormat.applyPattern("##,###.000");

                                         System.out.println(addPattenFormat.format(111111123456.1227));

      

       DecimalFormat zhiFormat = new DecimalFormat();

       zhiFormat.applyPattern("0.000E0000");

       System.out.println(zhiFormat.format(10000));

       System.out.println(zhiFormat.format(12345678.345));

      

       DecimalFormat percentFormat = new DecimalFormat();

       percentFormat.applyPattern("#0.000%");

       System.out.println(percentFormat.format(0.3052222));

       結果

       1111,1112,3456.123

111,111,123,456.123

111,111,123,456.123

1.000E0004

1.235E0007

30.522%

如果使用具有多個分組字符的模式,則最後一個分隔符和整數結尾之間的間隔纔是使用的分組大小。所以 "#,##,###,####" == "######,####" == "##,####,####"。

 

本文來自CSDN博客,轉載請標明出處:http://blog.csdn.net/kjfcpua/archive/2009/06/03/4240486.aspx

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章