真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網站制作重慶分公司

java代碼怎么寫成表格 java代碼生成excel

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

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

成都創(chuàng)新互聯(lián)專注于巴中企業(yè)網站建設,響應式網站設計,商城網站建設。巴中網站建設公司,為巴中等地區(qū)提供建站服務。全流程定制制作,專業(yè)設計,全程項目跟蹤,成都創(chuàng)新互聯(lián)專業(yè)和態(tài)度為您提供的服務

一.讀取Excel文件內容

/**讀取Excel文件的內容

* @param file 待讀取的文件

* @return

*/

public static String readExcel(File file){

StringBuffer sb = new StringBuffer();

Workbook wb = null;

try {

//構造Workbook(工作薄)對象

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++){

//得到當前工作表的行數

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(" ");

}

}

//最后關閉資源,釋放內存

wb.close();

return sb.toString();

}

二.寫入Excel文件

這里有很多格式了,比如文本內容加粗,加上某些顏色等,可以參考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方法有兩個參數,第一個是工作表的名稱,第二個是工作表在工作薄中的位置

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

//下面開始添加單元格

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

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

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

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 {

//從內存中寫入文件中

wwb.write();

//關閉資源,釋放內存

wwb.close();

} catch (IOException e) {

e.printStackTrace();

} catch (WriteException e) {

e.printStackTrace();

}

}

}

三.在一個Excel文件中查找是否包含某一個關鍵字

/**搜索某一個文件中是否包含某個關鍵字

* @param file 待搜索的文件

* @param keyWord 要搜索的關鍵字

* @return

*/

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

boolean res = false;

Workbook wb = null;

try {

//構造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;

//得到當前工作表的行數

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;

}

}

}

}

}

}

//最后關閉資源,釋放內存

wb.close();

return res;

}

四.往Excel中插入圖片圖標

插入圖片的實現很容易,參看以下代碼:

/**往Excel中插入圖片

* @param dataSheet 待插入的工作表

* @param col 圖片從該列開始

* @param row 圖片從該行開始

* @param width 圖片所占的列數

* @param height 圖片所占的行數

* @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);

}

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

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格式都不支持

五.插入頁眉頁腳

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

/**向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();

}

六偷懶工具設計之sql2Excel

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

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

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

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");

//配置數據源

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

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

}

/**得到查詢結果集

* @param sql

* @return

* @throws SQLException

*/

public ResultSet getResultSet(String sql) throws SQLException{

state = con.createStatement();

ResultSet res = state.executeQuery(sql);

return res;

}

/**關閉連接

* @throws SQLException

*/

public void close() throws SQLException{

if(con!=null)

con.close();

if(state!=null)

state.close();

}

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

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

/**將查詢結果寫入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 {

//從內存中寫入文件中

wwb.write();

//關閉資源,釋放內存

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 如何寫excel

public static void main(String[] args) throws IOException {

//創(chuàng)建工作簿對象

HSSFWorkbook wb=new HSSFWorkbook();

//創(chuàng)建工作表對象

HSSFSheet sheet=wb.createSheet("我的工作表");

//創(chuàng)建繪圖對象

HSSFPatriarch p=sheet.createDrawingPatriarch();

//創(chuàng)建單元格對象,批注插入到4行,1列,B5單元格

HSSFCell cell=sheet.createRow(4).createCell(1);

//插入單元格內容

cell.setCellValue(new HSSFRichTextString("批注"));

//獲取批注對象

//(int dx1, int dy1, int dx2, int dy2, short col1, int row1, short col2, int row2)

//前四個參數是坐標點,后四個參數是編輯和顯示批注時的大小.

HSSFComment comment=p.createComment(new HSSFClientAnchor(0,0,0,0,(short)3,3,(short)5,6));

//輸入批注信息

comment.setString(new HSSFRichTextString("插件批注成功!插件批注成功!"));

//添加作者,選中B5單元格,看狀態(tài)欄

comment.setAuthor("toad");

//將批注添加到單元格對象中

cell.setCellComment(comment);

//創(chuàng)建輸出流

FileOutputStream out=new FileOutputStream("writerPostil.xls");

wb.write(out);

//關閉流對象

out.close();

}

Aspose.cell for Java+Aspose.PDF for Java 可以實現,但是網上Aspose的jar包貌似沒破解的,點虐 的倒挺多.

java中輸入輸出流如何把數據輸出為Excel表格形式

實現代碼如下:

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);//設置cell的整數類型的值

// Or do it on one line.

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

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

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

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

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

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

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

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

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

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

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

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面向對象程序設計語言(以下簡稱Java語言)和Java平臺的總稱。由James Gosling和同事們共同研發(fā),并在1995年正式推出。Java最初被稱為Oak,是1991年為消費類電子產品的嵌入式芯片而設計的。1995年更名為Java,并重新設計用于開發(fā)Internet應用程序。

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


標題名稱:java代碼怎么寫成表格 java代碼生成excel
瀏覽路徑:http://weahome.cn/article/ddehcii.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部