java代碼輸出單元格 java代碼輸出結(jié)果

java中輸入輸出流如何把數(shù)據(jù)輸出為Excel表格形式

實現(xiàn)代碼如下:

公司主營業(yè)務(wù):成都網(wǎng)站建設(shè)、網(wǎng)站設(shè)計、移動網(wǎng)站開發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競爭能力。創(chuàng)新互聯(lián)是一支青春激揚、勤奮敬業(yè)、活力青春激揚、勤奮敬業(yè)、活力澎湃、和諧高效的團隊。公司秉承以“開放、自由、嚴謹、自律”為核心的企業(yè)文化,感謝他們對我們的高要求,感謝他們從不同領(lǐng)域給我們帶來的挑戰(zhàn),讓我們激情的團隊有機會用頭腦與智慧不斷的給客戶帶來驚喜。創(chuàng)新互聯(lián)推出猇亭免費做網(wǎng)站回饋大家。

import org.apache.poi.hssf.usermodel.*;

import java.io.FileOutputStream;

import java.io.IOException;

publicclass CreateCells

{

publicstaticvoid main(String[] args)

throws IOException

{

HSSFWorkbook wb = new HSSFWorkbook();//建立新HSSFWorkbook對象

HSSFSheet sheet = wb.createSheet("new sheet");//建立新的sheet對象

// Create a row and put some cells in it. Rows are 0 based.

HSSFRow row = sheet.createRow((short)0);//建立新行

// Create a cell and put a value in it.

HSSFCell cell = row.createCell((short)0);//建立新cell

cell.setCellValue(1);//設(shè)置cell的整數(shù)類型的值

// Or do it on one line.

row.createCell((short)1).setCellValue(1.2);//設(shè)置cell浮點類型的值

row.createCell((short)2).setCellValue("test");//設(shè)置cell字符類型的值

row.createCell((short)3).setCellValue(true);//設(shè)置cell布爾類型的值

HSSFCellStyle cellStyle = wb.createCellStyle();//建立新的cell樣式

cellStyle.setDataFormat(HSSFDataFormat.getFormat("m/d/yy h:mm"));//設(shè)置cell樣式為定制的日期格式

HSSFCell dCell =row.createCell((short)4);

dCell.setCellValue(new Date());//設(shè)置cell為日期類型的值

dCell.setCellStyle(cellStyle); //設(shè)置該cell日期的顯示格式

HSSFCell csCell =row.createCell((short)5);

csCell.setEncoding(HSSFCell.ENCODING_UTF_16);//設(shè)置cell編碼解決中文高位字節(jié)截斷

csCell.setCellValue("中文測試_Chinese Words Test");//設(shè)置中西文結(jié)合字符串

row.createCell((short)6).setCellType(HSSFCell.CELL_TYPE_ERROR);//建立錯誤cell

// Write the output to a file

FileOutputStream fileOut = new FileOutputStream("workbook.xls");

wb.write(fileOut);

fileOut.close();

}

}

Java是由Sun Microsystems公司推出的Java面向?qū)ο蟪绦蛟O(shè)計語言(以下簡稱Java語言)和Java平臺的總稱。由James Gosling和同事們共同研發(fā),并在1995年正式推出。Java最初被稱為Oak,是1991年為消費類電子產(chǎn)品的嵌入式芯片而設(shè)計的。1995年更名為Java,并重新設(shè)計用于開發(fā)Internet應(yīng)用程序。

用Java實現(xiàn)的HotJava瀏覽器(支持Java applet)顯示了Java的魅力:跨平臺、動態(tài)Web、Internet計算。從此,Java被廣泛接受并推動了Web的迅速發(fā)展,常用的瀏覽器均支持Javaapplet。另一方面,Java技術(shù)也不斷更新。Java自面世后就非常流行,發(fā)展迅速,對C++語言形成有力沖擊。在全球云計算和移動互聯(lián)網(wǎng)的產(chǎn)業(yè)環(huán)境下,Java更具備了顯著優(yōu)勢和廣闊前景。2010年Oracle公司收購Sun Microsystems。

如何使用java代碼實現(xiàn)設(shè)置excel單元格的格式。

import

org.apache.poi.hssf.usermodel.HSSFCell;

import

org.apache.poi.hssf.usermodel.HSSFCellStyle;

import

org.apache.poi.hssf.usermodel.HSSFRow;

import

org.apache.poi.hssf.usermodel.HSSFSheet;

import

org.apache.poi.hssf.usermodel.HSSFWorkbook;

import

org.apache.poi.poifs.filesystem.POIFSFileSystem;

/**

*

@param

inputFile

輸入模板文件路徑

*

@param

outputFile

輸入文件存放于服務(wù)器路徑

*

@param

dataList

待導出數(shù)據(jù)

*

@throws

Exception

*

@roseuid:

*/

public

void

exportExcelFile(String

inputFile,

String

outputFile,

List

dataList)

throws

Exception

{

//用模板文件構(gòu)造poi

POIFSFileSystem

fs

=

new

POIFSFileSystem(new

FileInputStream(inputFile));

//創(chuàng)建模板工作表

HSSFWorkbook

templatewb

=

new

HSSFWorkbook(fs);

//直接取模板第一個sheet對象

HSSFSheet

templateSheet

=

templatewb.getSheetAt(1);

//得到模板的第一個sheet的第一行對象

為了得到模板樣式

HSSFRow

templateRow

=

templateSheet.getRow(0);

//HSSFSheet

timplateSheet

=

templatewb.getSheetAt(1);

//取得Excel文件的總列數(shù)

int

columns

=

templateSheet.getRow((short)

0).getPhysicalNumberOfCells();

Debug.println("columns

is

:

"

+

columns);

//創(chuàng)建樣式數(shù)組

HSSFCellStyle

styleArray[]

=

new

HSSFCellStyle[columns];

//一次性創(chuàng)建所有列的樣式放在數(shù)組里

for

(int

s

=

0;

s

columns;

s++)

{

//得到數(shù)組實例

styleArray[s]

=

templatewb.createCellStyle();

}

//循環(huán)對每一個單元格進行賦值

//定位行

for

(int

rowId

=

1;

rowId

dataList.size();

rowId++)

{

//依次取第rowId行數(shù)據(jù)

每一個數(shù)據(jù)是valueList

List

valueList

=

(List)

dataList.get(rowId

-

1);

//定位列

for

(int

columnId

=

0;

columnId

columns;

columnId++)

{

//依次取出對應(yīng)與colunmId列的值

//每一個單元格的值

String

dataValue

=

(String)

valueList.get(columnId);

//取出colunmId列的的style

//模板每一列的樣式

HSSFCellStyle

style

=

styleArray[columnId];

//取模板第colunmId列的單元格對象

//模板單元格對象

HSSFCell

templateCell

=

templateRow.getCell((short)

columnId);

//創(chuàng)建一個新的rowId行

行對象

//新建的行對象

HSSFRow

hssfRow

=

templateSheet.createRow(rowId);

//創(chuàng)建新的rowId行

columnId列

單元格對象

//新建的單元格對象

HSSFCell

cell

=

hssfRow.createCell((short)

columnId);

//如果對應(yīng)的模板單元格

樣式為非鎖定

if

(templateCell.getCellStyle().getLocked()

==

false)

{

//設(shè)置此列style為非鎖定

style.setLocked(false);

//設(shè)置到新的單元格上

cell.setCellStyle(style);

}

//否則樣式為鎖定

else

{

//設(shè)置此列style為鎖定

style.setLocked(true);

//設(shè)置到新單元格上

cell.setCellStyle(style);

}

//設(shè)置編碼

cell.setEncoding(HSSFCell.ENCODING_UTF_16);

//Debug.println("dataValue

:

"

+

dataValue);

//設(shè)置值

統(tǒng)一為String

cell.setCellValue(dataValue);

}

}

//設(shè)置輸入流

FileOutputStream

fOut

=

new

FileOutputStream(outputFile);

//將模板的內(nèi)容寫到輸出文件上

templatewb.write(fOut);

fOut.flush();

//操作結(jié)束,關(guān)閉文件

fOut.close();

}

java如何輸出xls格式的Excel表格文件

有個開源的東東-jxl.jar,可以到下載。

一.讀取Excel文件內(nèi)容

/**讀取Excel文件的內(nèi)容

* @param file 待讀取的文件

* @return

*/

public static String readExcel(File file){

StringBuffer sb = new StringBuffer();

Workbook wb = null;

try {

//構(gòu)造Workbook(工作?。ο?/p>

wb=Workbook.getWorkbook(file);

} catch (BiffException e) {

e.printStackTrace();

} catch (IOException e) {

e.printStackTrace();

}

if(wb==null)

return null;

//獲得了Workbook對象之后,就可以通過它得到Sheet(工作表)對象了

Sheet[] sheet = wb.getSheets();

if(sheet!=nullsheet.length0){

//對每個工作表進行循環(huán)

for(int i=0;isheet.length;i++){

//得到當前工作表的行數(shù)

int rowNum = sheet[i].getRows();

for(int j=0;jrowNum;j++){

//得到當前行的所有單元格

Cell[] cells = sheet[i].getRow(j);

if(cells!=nullcells.length0){

//對每個單元格進行循環(huán)

for(int k=0;kcells.length;k++){

//讀取當前單元格的值

String cellValue = cells[k].getContents();

sb.append(cellValue+" ");

}

}

sb.append(" ");

}

sb.append(" ");

}

}

//最后關(guān)閉資源,釋放內(nèi)存

wb.close();

return sb.toString();

}

二.寫入Excel文件

這里有很多格式了,比如文本內(nèi)容加粗,加上某些顏色等,可以參考jxl的api,同時還推薦一篇不錯的文章:

/**生成一個Excel文件

* @param fileName 要生成的Excel文件名

*/

public static void writeExcel(String fileName){

WritableWorkbook wwb = null;

try {

//首先要使用Workbook類的工廠方法創(chuàng)建一個可寫入的工作薄(Workbook)對象

wwb = Workbook.createWorkbook(new File(fileName));

} catch (IOException e) {

e.printStackTrace();

}

if(wwb!=null){

//創(chuàng)建一個可寫入的工作表

//Workbook的createSheet方法有兩個參數(shù),第一個是工作表的名稱,第二個是工作表在工作薄中的位置

WritableSheet ws = wwb.createSheet("sheet1", 0);

//下面開始添加單元格

for(int i=0;i10;i++){

for(int j=0;j5;j++){

//這里需要注意的是,在Excel中,第一個參數(shù)表示列,第二個表示行

Label labelC = new Label(j, i, "這是第"+(i+1)+"行,第"+(j+1)+"列");

try {

//將生成的單元格添加到工作表中

ws.addCell(labelC);

} catch (RowsExceededException e) {

e.printStackTrace();

} catch (WriteException e) {

e.printStackTrace();

}

}

}

try {

//從內(nèi)存中寫入文件中

wwb.write();

//關(guān)閉資源,釋放內(nèi)存

wwb.close();

} catch (IOException e) {

e.printStackTrace();

} catch (WriteException e) {

e.printStackTrace();

}

}

}

三.在一個Excel文件中查找是否包含某一個關(guān)鍵字

/**搜索某一個文件中是否包含某個關(guān)鍵字

* @param file 待搜索的文件

* @param keyWord 要搜索的關(guān)鍵字

* @return

*/

public static boolean searchKeyWord(File file,String keyWord){

boolean res = false;

Workbook wb = null;

try {

//構(gòu)造Workbook(工作?。ο?/p>

wb=Workbook.getWorkbook(file);

} catch (BiffException e) {

return res;

} catch (IOException e) {

return res;

}

if(wb==null)

return res;

//獲得了Workbook對象之后,就可以通過它得到Sheet(工作表)對象了

Sheet[] sheet = wb.getSheets();

boolean breakSheet = false;

if(sheet!=nullsheet.length0){

//對每個工作表進行循環(huán)

for(int i=0;isheet.length;i++){

if(breakSheet)

break;

//得到當前工作表的行數(shù)

int rowNum = sheet[i].getRows();

boolean breakRow = false;

for(int j=0;jrowNum;j++){

if(breakRow)

break;

//得到當前行的所有單元格

Cell[] cells = sheet[i].getRow(j);

if(cells!=nullcells.length0){

boolean breakCell = false;

//對每個單元格進行循環(huán)

for(int k=0;kcells.length;k++){

if(breakCell)

break;

//讀取當前單元格的值

String cellValue = cells[k].getContents();

if(cellValue==null)

continue;

if(cellValue.contains(keyWord)){

res = true;

breakCell = true;

breakRow = true;

breakSheet = true;

}

}

}

}

}

}

//最后關(guān)閉資源,釋放內(nèi)存

wb.close();

return res;

}

四.往Excel中插入圖片圖標

插入圖片的實現(xiàn)很容易,參看以下代碼:

/**往Excel中插入圖片

* @param dataSheet 待插入的工作表

* @param col 圖片從該列開始

* @param row 圖片從該行開始

* @param width 圖片所占的列數(shù)

* @param height 圖片所占的行數(shù)

* @param imgFile 要插入的圖片文件

*/

public static void insertImg(WritableSheet dataSheet, int col, int row, int width,

int height, File imgFile){

WritableImage img = new WritableImage(col, row, width, height, imgFile);

dataSheet.addImage(img);

}

以上代碼的注釋已經(jīng)很清楚了,大概也就不用再解釋了,我們可以用如下程序驗證:

try {

//創(chuàng)建一個工作薄

WritableWorkbook workbook = Workbook.createWorkbook(new File("D:/test1.xls"));

//待插入的工作表

WritableSheet imgSheet = workbook.createSheet("Images",0);

//要插入的圖片文件

File imgFile = new File("D:/1.png");

//圖片插入到第二行第一個單元格,長寬各占六個單元格

insertImg(imgSheet,0,1,6,6,imgFile);

workbook.write();

workbook.close();

} catch (IOException e) {

e.printStackTrace();

} catch (WriteException e) {

e.printStackTrace();

}

但是jxl只支持png格式的圖片,jpg格式和gif格式都不支持

五.插入頁眉頁腳

一般的頁眉頁腳都分為三個部分,左,中,右三部分,利用如下代碼可實現(xiàn)插入頁眉頁腳

/**向Excel中加入頁眉頁腳

* @param dataSheet 待加入頁眉的工作表

* @param left

* @param center

* @param right

*/

public static void setHeader(WritableSheet dataSheet,String left,String center,String right){

HeaderFooter hf = new HeaderFooter();

hf.getLeft().append(left);

hf.getCentre().append(center);

hf.getRight().append(right);

//加入頁眉

dataSheet.getSettings().setHeader(hf);

//加入頁腳

//dataSheet.getSettings().setFooter(hf);

}

我們可以用如下代碼測試該方法:

try {

//創(chuàng)建一個工作薄

WritableWorkbook workbook = Workbook.createWorkbook(new File("D:/test1.xls"));

//待插入的工作表

WritableSheet dataSheet = workbook.createSheet("加入頁眉",0);

ExcelUtils.setHeader(dataSheet, "chb", "2007-03-06", "第1頁,共3頁");

workbook.write();

workbook.close();

} catch (IOException e) {

e.printStackTrace();

} catch (WriteException e) {

e.printStackTrace();

}

六偷懶工具設(shè)計之sql2Excel

今天在公司陪山東客戶調(diào)試,遠程登錄,我在linux下什么工具都沒有,用ssh登錄服務(wù)器,直接用mysql查詢數(shù)據(jù)庫,提出記錄中的所有漢字全是亂碼。哎,可惡的公司,不讓我用windows,要不我就可以用putty或者EMS了,我ft!

甚是不爽之下,我決定自己寫個工具了,把客戶數(shù)據(jù)庫中的數(shù)據(jù)全部提取并保存到Excel中,這樣我不就可以一目了然了嘛,嘿嘿,好吧,那我就寫一個工具吧。

第一部分就是誰都會的jdbc操作,連接數(shù)據(jù)庫,提取數(shù)據(jù)集合。

Connection con;

Statement state;

/**初始化連接

* @param serverIp

* @param dataBase

* @param userName

* @param password

* @throws ClassNotFoundException

* @throws SQLException

*/

public void init(String serverIp,String dataBase,String userName,String password) throws ClassNotFoundException, SQLException{

Class.forName("com.mysql.jdbc.Driver");

//配置數(shù)據(jù)源

String url="jdbc:mysql://"+serverIp+"/"+dataBase+"?useUnicode=truecharacterEncoding=GB2312";

con=DriverManager.getConnection(url,userName,password);

}

/**得到查詢結(jié)果集

* @param sql

* @return

* @throws SQLException

*/

public ResultSet getResultSet(String sql) throws SQLException{

state = con.createStatement();

ResultSet res = state.executeQuery(sql);

return res;

}

/**關(guān)閉連接

* @throws SQLException

*/

public void close() throws SQLException{

if(con!=null)

con.close();

if(state!=null)

state.close();

}

第二部分就是把ResultSet中的記錄寫入一個Excel文件

操作Excel,我用的是jxl,不熟的同學可以參考:利用java操作Excel文件

/**將查詢結(jié)果寫入Excel文件中

* @param rs

* @param file

* @throws SQLException

*/

public void writeExcel(ResultSet rs,File file) throws SQLException{

WritableWorkbook wwb = null;

try{

//首先要使用Workbook類的工廠方法創(chuàng)建一個可寫入的工作薄(Workbook)對象

wwb = Workbook.createWorkbook(file);

} catch (IOException e){

e.printStackTrace();

}

if(wwb!=null){

WritableSheet ws = wwb.createSheet("sheet1", 0);

int i=0;

while(rs.next()){

Label label1 = new Label(0, i, rs.getString("id"));

Label label2 = new Label(1, i, rs.getString("category"));

try {

ws.addCell(label1);

ws.addCell(label2);

} catch (RowsExceededException e) {

e.printStackTrace();

} catch (WriteException e) {

e.printStackTrace();

}

i++;

}

try {

//從內(nèi)存中寫入文件中

wwb.write();

//關(guān)閉資源,釋放內(nèi)存

wwb.close();

} catch (IOException e) {

e.printStackTrace();

} catch (WriteException e){

e.printStackTrace();

}

}

}

測試程序:

Sql2Excel se = new Sql2Excel();

try {

se.init("127.0.0.1","mydabase", "root", "1234");

ResultSet rs = se.getResultSet("select id,category from xx ");

se.writeExcel(rs, new File("/root/sql2excel.xls"));

se.close();

} catch (ClassNotFoundException e) {

e.printStackTrace();

} catch (SQLException e) {

e.printStackTrace();

}

當前題目:java代碼輸出單元格 java代碼輸出結(jié)果
轉(zhuǎn)載來于:http://bm7419.com/article12/ddcsdgc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供面包屑導航云服務(wù)器、響應(yīng)式網(wǎng)站、外貿(mào)建站、營銷型網(wǎng)站建設(shè)網(wǎng)站策劃

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都做網(wǎng)站