Java利用POI生成Excel强制换行

使用POI创建一个简单的   myXls.xls   文件   
    
常用的包为   org.apache.poi.hssf.usermodel.*;   
例子:   
    
import   java.io.*;   
import   org.apache.poi.hssf.usermodel.*;   
    
public   class   ZoomSheet   {   
    
          public   ZoomSheet()   {   
          }   
    
          public   static   void   main(String   args[])   
                  throws   IOException   {   
    
                  HSSFWorkbook   wb   =   new   HSSFWorkbook();   
                  HSSFSheet   sheet1   =   wb.createSheet("new   sheet");   
                  FileOutputStream   fileOut   =   new   FileOutputStream("workbook.xls");   
                  wb.write(fileOut);   
                  fileOut.close();   
          }   
}   
    
类:   
HSSFWorkbook 创建   xls   的对象; HSSFWorkbook   hw   =   new   HSSFWorkbook();                   
设置分区显示; hw.setRepeatingRowsAndColumns(sheet的index,   行,   列,   行,   列);   
HSSFSheet 创建   xls   中的sheet(工作表); HSSFSheet   sheet   =   hw.createSheet("sheet1");       sheet1   是   sheet   的名称   可缺省   
设置列高; sheet.setColumnWidth((short)short,   (short)short);   
HSSFRow 创建   xls   中的行; HSSFRow   row   =   sheet.createRow(0);                             0   表示第一行   
设置行高; row.setHeight((short)short);   
HSSFFont 创建   xls   中的字体; HSSFFont   font   =   hw.createFont();   
设定字体大小; font.setFontHeightInPoints((short)54);   
设定为斜体; font.setItalic(true);   
设定文字删除线; font.setStrikeout(true);   
HSSFCellStyle 设定单元格风格; HSSFCellStyle   style   =   wb.createCellStyle();   
加入字体; style.setFont(font);   
HSSFCell 设定单元格; HSSFCell   cell   =   row.createCell((short)0);   
单元格水平对齐方式; style.setAlignment(align);         //单元格水平   0   普通   1   左对齐   2   居中   3   右对齐   4   填充   5   正当   6   居中选择   
单元格垂直对齐方式; style.setVerticalAlignment(align);       //单元格垂直   0   居上   1   居中   2   居下   3   正当   
    
单元格下边框为细线; style.setBorderBottom((short)short);   
同上一命令一同使用,设置颜色; style.setBottomBorderColor((short)short);   
单元格左边框; style.setBorderLeft((short)short);   
style.setLeftBorderColor((short)short);   
单元格右边框; style.setBorderRight((short)short);   
style.setRightBorderColor((short)short);   
单元格上边框; style.setBorderTop((short)short);   
style.setTopBorderColor((short)short);   
单元格字符编号(中文); cell.setEncoding(HSSFCell.ENCODING_UTF_16);       //中文   
单元格显示的值; cell.setCellValue("中医药");     值的类型有:double,int,String,Date,boolean   
单元格背景色; style.setFillForegroundColor((short)short);   
图案类型; style.setFillPattern((short)short);   
单元格合并; sheet.addMergedRegion(new   Region(行,   (short)列,   行,   (short)列));   
    
    
单元格风格加入; cell.setCellStyle(style);   
    
                
    
    
打印设置   
引入包 import   org.apache.poi.hssf.usermodel.HSSFPrintSetup;   
创建打印设置对象 HSSFPrintSetup   hps   =   hs.getPrintSetup();   
设置A4纸 hps.setPaperSize((short)9);       
将页面设置为横向打印模式 hps.setLandscape(true);     
    
设置打印页面为水平居中 sheet.setHorizontallyCenter(true);         
设置打印页面为垂直居中 sheet.setVerticallyCenter(true);

网上找到的文章都是说在excel里的文字里加上\n,\n\r,\r\n之类,反正各种各样的都有,更奇怪的是还有人说在单元格里加上<br> 
后来我试过用\r后的效里是生成的文件里,你用打开时,并不会换行,如果你用鼠标在单元格里点一下之后就会自动换行。

可以通过如下方式进行,
1. 首先在需要强制换行的单元格里使用poi的样式,并且把样式设定为自动换行 
   # HSSFCellStyle cellStyle=workbook.createCellStyle();     
   # cellStyle.setWrapText(true);     
   # cell.setCellStyle(cellStyle); 
2. 其次是在需要强制换行的单元格,使用\就可以实再强制换行 
   1. HSSFCell cell = row.createCell((short)0); 
   2. cell.setCellStyle(cellStyle);                           cell.setCellValue(new HSSFRichTextString("hello\r\n world!")); 
这样就能实现强制换行,
换行后的效里是单元格里强制换行
hello
world!

 
 

public class ExcelTest {
  /**   
  * @param args   
  */   
  public static void main(String[] args) throws IOException {    
 
      try {    
          HSSFWorkbook wb = new HSSFWorkbook();    
          HSSFSheet sheet = wb.createSheet("new   sheet");    
          HSSFCellStyle style = wb.createCellStyle(); // 样式对象    
 
          style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);// 垂直    
          style.setAlignment(HSSFCellStyle.ALIGN_CENTER);// 水平    
          /**字体begin*/
          style.setFillForegroundColor(HSSFColor.SKY_BLUE.index); 
          //背景颜色
//          style.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);
//          style.setBorderBottom(HSSFCellStyle.BORDER_THIN);
//          style.setBorderLeft(HSSFCellStyle.BORDER_THIN);
//          style.setBorderRight(HSSFCellStyle.BORDER_THIN);
//          style.setBorderTop(HSSFCellStyle.BORDER_THIN);
//          style.setAlignment(HSSFCellStyle.ALIGN_CENTER);
          
          //生成一个字体
          HSSFFont font=wb.createFont();
          font.setColor(HSSFColor.BLACK.index);//HSSFColor.VIOLET.index //字体颜色
          font.setFontHeightInPoints((short)12);
          font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);         //字体增粗
         //把字体应用到当前的样式
          style.setFont(font);
          /**字体end*/
          HSSFRow row = sheet.createRow((short) 0);    
          HSSFRow row2 = sheet.createRow((short) 1);    
          
          // 四个参数分别是:起始行,起始列,结束行,结束列    
          sheet.addMergedRegion(new Region(0, (short) 0, 5, (short) 0));    
          HSSFCell ce = row.createCell((short) 0);    
          ce.setCellValue("项目\\日期"); // 表格的第一行第一列显示的数据    
          ce.setCellStyle(style); // 样式,居中    
          int num = 0;    
          for (int i = 0; i < 9; i++) { // 循环9次,每一次都要跨单元格显示    
              // 计算从那个单元格跨到那一格    
              int celln = 0;    
              int celle = 0;    
              if (i == 0) {    
                  celln = 0;    
                  celle = 1;    
              } else {    
                  celln = (i * 2);    
                  celle = (i * 2 + 1);    
              }    
              // 单元格合并    
              // 四个参数分别是:起始行,起始列,结束行,结束列    
              sheet.addMergedRegion(new Region(0, (short) (celln + 1), 0,    
                      (short) (celle + 1)));    
              HSSFCell cell = row.createCell((short) (celln + 1));    
              cell.setCellValue("merging" + i); // 跨单元格显示的数据    
              cell.setCellStyle(style); // 样式    
              // 不跨单元格显示的数据,如:分两行,上一行分别两格为一格,下一行就为两格,“数量”,“金额”    
              HSSFCell cell1 = row2.createCell((short) celle);    
              HSSFCell cell2 = row2.createCell((short) (celle + 1));    
              cell1.setCellValue("数量");    
              cell1.setCellStyle(style);    
              cell2.setCellValue("金额");    
              cell2.setCellStyle(style);    
              num++;    
          }    
 
          // 在后面加上合计百分比    
 
          // 合计 在最后加上,还要跨一个单元格     //四个参数分别是:起始行,起始列,结束行,结束列    
          sheet.addMergedRegion(new Region(0, (short) (2 * num + 1), 0,    
                  (short) (2 * num + 2)));    
          HSSFCell cell = row.createCell((short) (2 * num + 1));    
          cell.setCellValue("合计");    
          cell.setCellStyle(style);  
          HSSFCell cell1 = row2.createCell((short) (2 * num + 1));    
          HSSFCell cell2 = row2.createCell((short) (2 * num + 2));    
          cell1.setCellValue("数量");    
          cell1.setCellStyle(style);    
          cell2.setCellValue("金额");    
          cell2.setCellStyle(style);    
 
          // 百分比 同上    
          sheet.addMergedRegion(new Region(0, (short) (2 * num + 3), 0,    
                  (short) (2 * num + 4)));    
          HSSFCell cellb = row.createCell((short) (2 * num + 3));    
          cellb.setCellValue("百分比");    
          cellb.setCellStyle(style);    
          HSSFCell cellb1 = row2.createCell((short) (2 * num + 3));    
          HSSFCell cellb2 = row2.createCell((short) (2 * num + 4));    
          cellb1.setCellValue("数量");    
          cellb1.setCellStyle(style);    
          cellb2.setCellValue("金额");    
          cellb2.setCellStyle(style);  
          
          //输出一些数据 然后再输出表头
          
          FileOutputStream fileOut = new FileOutputStream("D://workbook.xls");   
          wb.write(fileOut);    
          fileOut.close();    
          System.out.print("OK");    
      } catch (Exception ex) {    
          ex.printStackTrace();    
      }    
 
  }

//设置单元格字体颜色

import Java.io.File;

import java.io.FileNotFoundException;

import java.io.FileOutputStream;

import java.io.IOException;

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

import org.apache.poi.hssf.util.HSSFColor;

import org.apache.poi.ss.usermodel.Cell;

import org.apache.poi.ss.usermodel.CreationHelper;

import org.apache.poi.ss.usermodel.Font;

import org.apache.poi.ss.usermodel.RichTextString;

import org.apache.poi.ss.usermodel.Sheet;

import org.apache.poi.ss.usermodel.Workbook;

public class test {

public static void main(String[] args) {

Workbook workbook = new HSSFWorkbook();

Sheet sheet = workbook.createSheet();

Cell cell = sheet.createRow(0).createCell(0);

CreationHelper helper = workbook.getCreationHelper();

RichTextString str = helper.createRichTextString("a\nb\nc\nd\ne\n");// 在这里使用\n表示回车

Font[] fonts = new Font[5];

fonts[0] = workbook.createFont();

fonts[0].setColor(HSSFColor.YELLOW.index);

fonts[1] = workbook.createFont();

fonts[1].setColor(HSSFColor.RED.index);

fonts[2] = workbook.createFont();

fonts[2].setColor(HSSFColor.BLUE.index);

fonts[3] = workbook.createFont();

fonts[3].setColor(HSSFColor.ROSE.index);

fonts[4] = workbook.createFont();

fonts[4].setColor(HSSFColor.BLACK.index);

for (int i = 0; i < 5; i++) {

str.applyFont(i * 2, (i + 1) * 2, fonts[i]);

}

cell.setCellValue(str);

try {

FileOutputStream out = new FileOutputStream(new File("d:\\1.xls"));

workbook.write(out);

out.close();

} catch (FileNotFoundException e) {

e.printStackTrace();

} catch (IOException e) {

e.printStackTrace();

}

}

}

POI设置excle单元格样式的更多相关文章

  1. poi的各种单元格样式以及一些常用的配置

    之前我做过一个poi到处excel数据的博客,但是,后面使用起来发现,导出的数据单元格样式都不对. 很多没有居中对齐,很多单元格的格式不对,还有就是单元格的大小不对,导致数据显示异常,虽然功能可以使用 ...

  2. POI HSSFCellStyle 设置 Excel 单元格样式

    POI中可能会用到一些需要设置EXCEL单元格格式的操作小结: 先获取工作薄对象: HSSFWorkbook wb = new HSSFWorkbook(); HSSFSheet sheet = wb ...

  3. 给bootstrap table设置行列单元格样式

    1.根据单元格或者行内其他单元格的内容,给该单元格设置一定的css样式 columns: [{ field: 'index', title: '序号', align:"center" ...

  4. POI 设置Excel单元格背景色(setFillForegroundColor)

    背景介绍:使用Java开发信息系统项目,项目中往往会涉及到报表管理部分,而Excel表格首当其冲称为最合适的选择,但是对单元格操作时对于设置单元格的背景颜色却很少提及,本文旨在方便单元格背景颜色设计. ...

  5. EXCEL设置选中单元格样式

    你想这样啊,试试这段代码看行不:右键工作表名称--查看代码,在空白处粘贴就可以 Private Sub Worksheet_SelectionChange(ByVal Target As Range) ...

  6. 【POI xlsx】使用POI对xlsx的单元格样式进行设置 / 使用POI对xlsx的字体进行设置

    涉及到的样式都在代码中有说明: package com.it.poiTest; import java.io.FileNotFoundException; import java.io.FileOut ...

  7. POI实现EXCEL单元格合并及边框样式

    POI实现EXCEL单元格合并及边框样式     下面例子为创建产生一个excel,合并单元格,然后为合并后的单元格添加边框 package test; import java.io.FileOutp ...

  8. 创建excel,合并单元格,设置单元格样式

    package com.huawei.excel; import java.io.File;import java.io.FileOutputStream;import java.util.Date; ...

  9. java POI Excel 单元格样式

    正如Html需要CSS一样,我们的POI生成的Excel同样需要样式才能更完美的表现我们的数据.下面还是从简单的例子出发,学习和了解POI的样式设计. 一.我的位置. 1 package com.my ...

随机推荐

  1. centos6.7环境之kvm虚拟化quem工具配置及使用详解

    环境准备 需要勾选CPU的虚拟化支持,支持cpu虚拟化的CPU列表: intel支持虚拟化技术CPU列表: Intel 6 Cores / 12 Threads CPU Number: Code Na ...

  2. Android:ZoomControls控件

    ZoomControls控件 //_ZoomControls.java public class _ZoomControls extends Activity{ @Override protected ...

  3. 利用pyecharts做地图数据展示

    首先, pip install pyecharts 为了地图上的数据能显示完全,加载好需要的城市地理坐标数据. pip install echarts-countries-pypkg pip inst ...

  4. Go语言规格说明书 之 类型(Types)

    go version go1.11 windows/amd64 本文为阅读Go语言中文官网的规则说明书(https://golang.google.cn/ref/spec)而做的笔记,完整的介绍Go语 ...

  5. 解决LoggerFactory is not a Logback LoggerContext but Logback is on the classpath

    因为引用了log4j2同时还引用了logback

  6. 队列queue 代码

    import queue q=queue.Queue(3) #队列:先进先出 q.put(1) q.put(2) q.put(3) q.put(4) print(q.get()) print(q.ge ...

  7. JavaScript 使用 mediaDevices API 选择摄像头

    大多数智能手机都有前置和后置摄像头,当你在创建视频应用时你可能想要选择或者切换前置.后置摄像头. 如果你开发的是一款聊天应用,你很可能会想调用前置摄像头,但如果你开发的是一款拍照软件,那么你会更倾向于 ...

  8. python 全栈开发,Day44(IO模型介绍,阻塞IO,非阻塞IO,多路复用IO,异步IO,IO模型比较分析,selectors模块,垃圾回收机制)

    昨日内容回顾 协程实际上是一个线程,执行了多个任务,遇到IO就切换 切换,可以使用yield,greenlet 遇到IO gevent: 检测到IO,能够使用greenlet实现自动切换,规避了IO阻 ...

  9. 2018-2019 2 20165203 《网络对抗技术》 Exp1 PC平台逆向破解

    2018-2019 2 20165203 <网络对抗技术> Exp1 PC平台逆向破解 实验要求 1.掌握NOP, JNE, JE, JMP, CMP汇编指令的机器码 2.掌握反汇编与十六 ...

  10. 微信小程序介绍

    1.什么是微信小程序 是一种不需要下载即可使用的应用,实现了“触手可及的梦想”,用户扫一扫或者搜一下即可打开. 免安装 操作更接近原始的APP 必须在微信中使用 2.宣传方式 小程序搜索入口 附近的小 ...