JAVA导入execl文件中文全角问题解决

   java导入execl时,录入字段中有中文全角问题,

   刚开始使用方法(不推荐):
/**
 * 去除字符串中头部和尾部所包含的空格(包括:空格(全角,半角)、制表符、换页符等)
 */
public static String trim(String s){
	String result = "";
	if(null!=s && !"".equals(s)){
		result = s.replaceAll("^[ *| *| *|//s*]*", "").replaceAll("[ *| *| *|//s*]*$", "");
	}
	return result;
}
不明白为什么会导致,导入时,有的字段读入不进去,有的value值会被截取,如:layers会被截取为layer。



解决,以下替换方法没有问题(推荐使用):
public String processingCell(XSSFRow xssfRow,int i){
	String parent = "";
	if("".equals(xssfRow.getCell(i)) || xssfRow.getCell(i) == null){}else{
        xssfRow.getCell(i).setCellType(CellType.STRING);
        parent = String.valueOf(CharMatcher.WHITESPACE.trimFrom(((xssfRow.getCell(i)).getStringCellValue())));
	}
	log.info("processingCell.parent::"+parent);
	return parent;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java中,可以使用Apache POI库来实现控制标点符号全角输入。下面是一个简单的代码示例: ```java import org.apache.poi.ss.usermodel.*; public class PoiExample { public static void main(String[] args) { Workbook workbook = WorkbookFactory.create(true); // 创建一个新的Excel文件 Sheet sheet = workbook.createSheet(); // 创建一个新的工作表 Font font = workbook.createFont(); // 创建一个字体对象 font.setBold(true); // 加粗 font.setTypeOffset(Font.SS_SUPER); // 上标 font.setColor(IndexedColors.RED.getIndex()); // 设置字体颜色 CellStyle style = workbook.createCellStyle(); // 创建一个单元格样式对象 style.setFont(font); // 设置字体 style.setWrapText(true); // 自动换行 style.setVerticalAlignment(VerticalAlignment.CENTER); // 垂直居中 style.setAlignment(HorizontalAlignment.CENTER); // 水平居中 style.setFillForegroundColor(IndexedColors.YELLOW.getIndex()); // 填充颜色 style.setFillPattern(FillPatternType.SOLID_FOREGROUND); // 填充模式 Row row = sheet.createRow(0); // 创建第一行 Cell cell = row.createCell(0); // 创建第一个单元格 cell.setCellValue("Hello, World!"); // 写入数据 cell.setCellStyle(style); // 应用样式 // 控制标点符号全角输入 String text = cell.getStringCellValue(); StringBuilder sb = new StringBuilder(); for (char c : text.toCharArray()) { if (c >= 33 && c <= 126) { sb.append((char) (c + 65248)); } else { sb.append(c); } } cell.setCellValue(sb.toString()); // 更新单元格数据 // 将Excel文件写入磁盘 try (FileOutputStream outputStream = new FileOutputStream("example.xlsx")) { workbook.write(outputStream); } catch (IOException e) { e.printStackTrace(); } System.out.println("Excel文件已生成!"); } } ``` 在上面的代码中,我们首先创建了一个Excel文件,并创建了一个工作表和一个单元格。然后,我们定义了一个单元格样式对象,并将其应用于单元格。接下来,我们使用StringBuilder类控制标点符号的全角输入。最后,我们将Excel文件写入磁盘并输出一条消息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值