欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java操作excel的方法

 更新時間:2015年07月14日 15:53:53   作者:愷哥  
這篇文章主要介紹了java操作excel的方法,實例分析了java針對excel文件的讀寫、打開、保存等操作技巧,需要的朋友可以參考下

本文實例講述了java操作excel的方法。分享給大家供大家參考。具體如下:

WritableWorkbook workbook = Workbook.createWorkbook(new File("d:\\output.xls")); 
 WritableSheet sheet = workbook.createSheet("項目簡報", 0); 
 //樣式 
 WritableFont sonti18font = new WritableFont(WritableFont.createFont("宋體"), 18,WritableFont.BOLD); 
 WritableFont sonti12font = new WritableFont(WritableFont.createFont("宋體"), 12,WritableFont.BOLD); 
 WritableFont sonti12fontNoBold = new WritableFont(WritableFont.createFont("宋體"), 12,WritableFont.NO_BOLD); 
 WritableCellFormat font18Subject = new WritableCellFormat (sonti18font); 
 WritableCellFormat font12Subject = new WritableCellFormat (sonti12font); 
 WritableCellFormat font12SubjectNoBold = new WritableCellFormat (sonti12fontNoBold); 
 font18Subject.setAlignment(jxl.format.Alignment.CENTRE); 
 font18Subject.setVerticalAlignment(jxl.format.VerticalAlignment.CENTRE);  
 font18Subject.setBorder(jxl.format.Border.ALL,jxl.format.BorderLineStyle.THIN);  
 font12Subject.setAlignment(jxl.format.Alignment.LEFT); 
 font12Subject.setVerticalAlignment(jxl.format.VerticalAlignment.CENTRE);  
 font12Subject.setBorder(jxl.format.Border.ALL,jxl.format.BorderLineStyle.THIN); 
 font12SubjectNoBold.setAlignment(jxl.format.Alignment.LEFT); 
 font12SubjectNoBold.setVerticalAlignment(jxl.format.VerticalAlignment.CENTRE);  
 font12SubjectNoBold.setBorder(jxl.format.Border.ALL,jxl.format.BorderLineStyle.THIN); 
 //樣式 end 
 //項目簡介信息 
 sheet.addCell(new Label(0, 0, projReportParam.getProj_name() + "項目簡報",font18Subject)); 
 sheet.mergeCells(0, 0, 5, 0); 
 sheet.addCell(new Label(0,1,"項目編號",font12Subject)); 
 sheet.addCell(new Label(1,1,projReportParam.getProj_code(),font12SubjectNoBold)); 
 sheet.addCell(new Label(2,1,"項目經(jīng)理",font12Subject)); 
 sheet.addCell(new Label(3,1,projReportParam.getEmp_name(),font12SubjectNoBold)); 
 sheet.addCell(new Label(4,1,"立項部門",font12Subject)); 
 sheet.addCell(new Label(5,1,projReportParam.getDept_name(),font12SubjectNoBold)); 
 sheet.addCell(new Label(0,2,"計劃發(fā)生成本",font12Subject)); 
 sheet.addCell(new Label(1,2,projReportParam.getPlan_cost(),font12SubjectNoBold)); 
 sheet.addCell(new Label(2,2,"實際發(fā)生成本",font12Subject)); 
 sheet.addCell(new Label(3,2,projReportParam.getActual_cost(),font12SubjectNoBold)); 
 sheet.addCell(new Label(0,3,"項目簡介",font12Subject)); 
 sheet.addCell(new Label(1,3,projReportParam.getProj_desc(),font12SubjectNoBold)); 
 sheet.mergeCells(1, 3, 5, 3); 
 //項目簡介信息 end 
 //里程碑 
 sheet.addCell(new Label(0,5,"里程碑",font18Subject)); 
 sheet.mergeCells(0, 5, 5, 5); 
 sheet.addCell(new Label(0,6,"階段名稱",font12Subject)); 
 sheet.addCell(new Label(1,6,"任務名稱",font12Subject)); 
 sheet.addCell(new Label(2,6,"實施人",font12Subject)); 
 sheet.addCell(new Label(3,6,"計劃起止時間",font12Subject)); 
 sheet.addCell(new Label(4,6,"實際起止時間",font12Subject)); 
 sheet.addCell(new Label(5,6,"狀態(tài)",font12Subject)); 
 int i = 7;//行 
 for(ProjReportParamMInfo projReportParamMInfo : projReportParam.getProjReportParamMInfoList()){ 
  sheet.addCell(new Label(0,i,projReportParamMInfo.getPharse_name(),font12SubjectNoBold)); 
  sheet.addCell(new Label(1,i,projReportParamMInfo.getTask_item(),font12SubjectNoBold)); 
  sheet.addCell(new Label(2,i,projReportParamMInfo.getEmp_name(),font12SubjectNoBold)); 
  sheet.addCell(new Label(3,i,Utils.formatDate(projReportParamMInfo.getTask_plan_sd()) + " / " + Utils.formatDate(projReportParamMInfo.getTask_plan_fd()),font12SubjectNoBold)); 
  sheet.addCell(new Label(4,i,Utils.formatDate(projReportParamMInfo.getTask_actual_sd()) + " / " + Utils.formatDate(projReportParamMInfo.getTask_actual_fd()),font12SubjectNoBold)); 
  sheet.addCell(new Label(5,i,projReportParamMInfo.getTask_state(),font12SubjectNoBold)); 
  i++; 
 } 
 //里程碑 end 
 //項目組成員及干系人 
 int j = 1+i;//行 
 sheet.addCell(new Label(0,j,"項目組成員及干系人",font18Subject)); 
 sheet.mergeCells(0, j, 5, j); 
 sheet.addCell(new Label(0,j+1,"序號",font12Subject)); 
 sheet.addCell(new Label(1,j+1,"姓名",font12Subject)); 
 sheet.addCell(new Label(2,j+1,"角色",font12Subject)); 
 sheet.addCell(new Label(3,j+1,"進入項目組時間",font12Subject)); 
 sheet.addCell(new Label(4,j+1,"離開項目組時間",font12Subject)); 
 sheet.addCell(new Label(5,j+1,"累計工時",font12Subject)); 
 int m = 1;//序號 
 int n = j+2;//行 
 for(ProjReportParamHRInfo projReportParamHRInfo : projReportParam.getProjReportParamHRInfoList()){ 
  sheet.addCell(new Label(0,n,m+"",font12SubjectNoBold)); 
  sheet.addCell(new Label(1,n,projReportParamHRInfo.getEmp_name(),font12SubjectNoBold)); 
  sheet.addCell(new Label(2,n,projReportParamHRInfo.getRole_name(),font12SubjectNoBold)); 
  sheet.addCell(new Label(3,n,Utils.formatDate(projReportParamHRInfo.getHr_start_date()),font12SubjectNoBold)); 
  sheet.addCell(new Label(4,n,Utils.formatDate(projReportParamHRInfo.getHr_release_date()),font12SubjectNoBold)); 
  sheet.addCell(new Label(5,n,projReportParamHRInfo.getTotal_manhour(),font12SubjectNoBold)); 
  m++; 
  n++; 
 } 
 //項目組成員及干系人 end 
 //本期工作內(nèi)容 
 int k = n + 1;//行 
 sheet.addCell(new Label(0,k,"本期工作內(nèi)容("+startDate+"至"+endDate+")",font18Subject)); 
 sheet.mergeCells(0, k, 6, k); 
 sheet.addCell(new Label(0,k+1,"任務編號",font12Subject)); 
 sheet.addCell(new Label(1,k+1,"任務名稱",font12Subject)); 
 sheet.addCell(new Label(2,k+1,"計劃起止時間",font12Subject)); 
 sheet.addCell(new Label(3,k+1,"實際起止時間",font12Subject)); 
 sheet.addCell(new Label(4,k+1,"計劃工時",font12Subject)); 
 sheet.addCell(new Label(5,k+1,"實際工時",font12Subject)); 
 sheet.addCell(new Label(6,k+1,"實施人員",font12Subject)); 
 int p = k + 2;//行 
 for(ProjReportParamTaskInfo projReportParamTaskInfo : projReportParam.getThisProjReportParamTaskInfoList()){ 
  sheet.addCell(new Label(0,p,projReportParamTaskInfo.getTask_code(),font12SubjectNoBold)); 
  sheet.addCell(new Label(1,p,projReportParamTaskInfo.getTask_item(),font12SubjectNoBold)); 
  sheet.addCell(new Label(2,p,Utils.formatDate(projReportParamTaskInfo.getTask_plan_sd()) + " / " + Utils.formatDate(projReportParamTaskInfo.getTask_plan_fd()),font12SubjectNoBold)); 
  sheet.addCell(new Label(3,p,Utils.formatDate(projReportParamTaskInfo.getTask_actual_sd()) + " / " + Utils.formatDate(projReportParamTaskInfo.getTask_actual_fd()),font12SubjectNoBold)); 
  sheet.addCell(new Label(4,p,projReportParamTaskInfo.getTask_plan_manhour(),font12SubjectNoBold)); 
  sheet.addCell(new Label(5,p,projReportParamTaskInfo.getTask_actual_manhour(),font12SubjectNoBold)); 
  sheet.addCell(new Label(6,p,projReportParamTaskInfo.getPlan_emp_name(),font12SubjectNoBold)); 
  p++; 
 } 
 //本期工作內(nèi)容 end 
 //下周工作內(nèi)容 
 int q = p + 1;//行 
 sheet.addCell(new Label(0,q,"下周工作內(nèi)容",font18Subject)); 
 sheet.mergeCells(0, q, 5, q); 
 sheet.addCell(new Label(0,q+1,"任務編號",font12Subject)); 
 sheet.addCell(new Label(1,q+1,"任務名稱",font12Subject)); 
 sheet.addCell(new Label(2,q+1,"計劃開始時間",font12Subject)); 
 sheet.addCell(new Label(3,q+1,"計劃結束時間",font12Subject)); 
 sheet.addCell(new Label(4,q+1,"計劃工時",font12Subject)); 
 sheet.addCell(new Label(5,q+1,"實施人員",font12Subject)); 
 int r = q + 2; 
 for(ProjReportParamTaskInfo projReportParamTaskInfo : projReportParam.getNextProjReportParamTaskInfoList()){ 
  sheet.addCell(new Label(0,r,projReportParamTaskInfo.getTask_code(),font12SubjectNoBold)); 
  sheet.addCell(new Label(1,r,projReportParamTaskInfo.getTask_item(),font12SubjectNoBold)); 
  sheet.addCell(new Label(2,r,Utils.formatDate(projReportParamTaskInfo.getTask_plan_sd()),font12SubjectNoBold)); 
  sheet.addCell(new Label(3,r,Utils.formatDate(projReportParamTaskInfo.getTask_plan_fd()),font12SubjectNoBold)); 
  sheet.addCell(new Label(4,r,projReportParamTaskInfo.getTask_plan_manhour(),font12SubjectNoBold)); 
  sheet.addCell(new Label(5,r,projReportParamTaskInfo.getPlan_emp_name(),font12SubjectNoBold)); 
  r++; 
 } 
 //下周工作內(nèi)容 end 
 //項目存在的問題及解決 
 int s = r + 1;//行 
 sheet.addCell(new Label(0,s,"項目存在的問題及解決",font18Subject)); 
 sheet.mergeCells(0, s, 8, s); 
 sheet.addCell(new Label(0,s+1,"識別日期",font12Subject)); 
 sheet.addCell(new Label(1,s+1,"問題描述",font12Subject)); 
 sheet.addCell(new Label(2,s+1,"所屬風險",font12Subject)); 
 sheet.addCell(new Label(3,s+1,"解決方法",font12Subject)); 
 sheet.addCell(new Label(4,s+1,"解決人",font12Subject)); 
 sheet.addCell(new Label(5,s+1,"計劃開始時間",font12Subject)); 
 sheet.addCell(new Label(6,s+1,"計劃完成時間",font12Subject)); 
 sheet.addCell(new Label(7,s+1,"問題狀態(tài)",font12Subject)); 
 sheet.addCell(new Label(8,s+1,"總結",font12Subject)); 
 int t = s + 2;//行 
 for(ProjReportParamRiskInfo projReportParamRiskInfo : projReportParam.getProjReportParamRiskInfoList()){ 
  sheet.addCell(new Label(0,t,Utils.formatDate(projReportParamRiskInfo.getSts_date()),font12SubjectNoBold)); 
  sheet.addCell(new Label(1,t,projReportParamRiskInfo.getProj_issue_item(),font12SubjectNoBold)); 
  sheet.addCell(new Label(2,t,projReportParamRiskInfo.getProj_risk_item(),font12SubjectNoBold)); 
  sheet.addCell(new Label(3,t,projReportParamRiskInfo.getIssue_resolve_method(),font12SubjectNoBold)); 
  sheet.addCell(new Label(4,t,projReportParamRiskInfo.getIssue_resolve_emp(),font12SubjectNoBold)); 
  sheet.addCell(new Label(5,t,Utils.formatDate(projReportParamRiskInfo.getIssue_plan_date()),font12SubjectNoBold)); 
  sheet.addCell(new Label(6,t,Utils.formatDate(projReportParamRiskInfo.getIssue_actual_date()),font12SubjectNoBold)); 
  sheet.addCell(new Label(7,t,projReportParamRiskInfo.getIssue_state(),font12SubjectNoBold)); 
  sheet.addCell(new Label(8,t,projReportParamRiskInfo.getIssue_summarize(),font12SubjectNoBold)); 
  t++; 
 } 
 //項目存在的問題及解決 end 
 workbook.write(); 
 workbook.close(); 
//生成項目簡報的程序

希望本文所述對大家的java程序設計有所幫助。

相關文章

  • MyBatis與Hibernate的比較

    MyBatis與Hibernate的比較

    Hibernate 與Mybatis都是流行的持久層開發(fā)框架,但Hibernate開發(fā)社區(qū)相對多熱鬧些,支持的工具也多,更新也快,當前最高版本4.1.8。而Mybatis相對平靜,工具較少,當前最高版本3.2
    2016-01-01
  • Java設置httponly?cookie的實現(xiàn)示例

    Java設置httponly?cookie的實現(xiàn)示例

    本文主要介紹了Java設置httponly?cookie的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-08-08
  • 用Java實現(xiàn)小球碰壁反彈的簡單實例(算法十分簡單)

    用Java實現(xiàn)小球碰壁反彈的簡單實例(算法十分簡單)

    下面小編就為大家?guī)硪黄肑ava實現(xiàn)小球碰壁反彈的簡單實例(算法十分簡單)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-08-08
  • java異常和錯誤類總結(必看篇)

    java異常和錯誤類總結(必看篇)

    下面小編就為大家?guī)硪黄猨ava異常和錯誤類總結(必看篇)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-09-09
  • Java實現(xiàn)學生管理系統(tǒng)

    Java實現(xiàn)學生管理系統(tǒng)

    這篇文章主要為大家詳細介紹了Java實現(xiàn)學生管理系統(tǒng),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • JDK都出到14了,你有什么理由不會函數(shù)式編程(推薦)

    JDK都出到14了,你有什么理由不會函數(shù)式編程(推薦)

    這篇文章主要介紹了JDK都出到14了,你有什么理由不會函數(shù)式編程,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-05-05
  • IntelliJ IDEA 刷題利器 LeetCode 插件詳解

    IntelliJ IDEA 刷題利器 LeetCode 插件詳解

    這篇文章主要介紹了IntelliJ IDEA 刷題利器 LeetCode 插件,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-08-08
  • SpringBoot Security前后端分離登錄驗證的實現(xiàn)

    SpringBoot Security前后端分離登錄驗證的實現(xiàn)

    這篇文章主要介紹了SpringBoot Security前后端分離登錄驗證的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-09-09
  • Spring的Bean注入解析結果BeanDefinition詳解

    Spring的Bean注入解析結果BeanDefinition詳解

    這篇文章主要介紹了Spring的Bean注入解析結果BeanDefinition詳解,BeanDefinition描述了一個bean實例,擁有屬性值、構造參數(shù)值和具體實現(xiàn)的其他信息,其是一個bean的元數(shù)據(jù),xml中配置的bean元素會被解析成BeanDefinition對象,需要的朋友可以參考下
    2023-12-12
  • java服務自動停止原因查找方式

    java服務自動停止原因查找方式

    這篇文章主要介紹了java服務自動停止原因查找方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-12-12

最新評論