如何使用Java避免excel中不可打印的字符?

如何使用Java避免excel中不可打印的字符?,java,excel,csv,Java,Excel,Csv,我使用附加代码将.XLSX文件转换为.CSV文件。除了一种情况外,它工作正常。代码无法处理不可打印的excel字符。如果它在excel中找到任何这样的字符,它将在CSV文件中创建一个额外的行。我无法说出它是什么字符,因为它在excel中不可见,并且当我应用excelClean()公式时,它正在消失 我如何用Java处理这个问题 谢谢 马杜 导入java.io.File; 导入java.io.FileInputStream; 导入java.io.FileOutputStream; 导入java.i

我使用附加代码将.XLSX文件转换为.CSV文件。除了一种情况外,它工作正常。代码无法处理不可打印的excel字符。如果它在excel中找到任何这样的字符,它将在CSV文件中创建一个额外的行。我无法说出它是什么字符,因为它在excel中不可见,并且当我应用excel
Clean()
公式时,它正在消失

我如何用Java处理这个问题

谢谢 马杜

导入java.io.File;
导入java.io.FileInputStream;
导入java.io.FileOutputStream;
导入java.io.FileWriter;
导入java.util.Iterator;
导入org.apache.poi.ss.usermodel.Cell;
导入org.apache.poi.ss.usermodel.Row;
导入org.apache.poi.xssf.usermodel.xssfheet;
导入org.apache.poi.xssf.usermodel.xssf工作簿;
类XlsxtoCSV{
静态void xlsx(文件输入文件、文件输出文件){
//用于将数据存储到CSV文件中
//System.out.println(“调用:方法”);
StringBuffer数据=新的StringBuffer();
试一试{
FileOutputStream fos=新的FileOutputStream(outputFile);
//获取XLSX文件的工作簿对象
XSSF工作簿wBook=新XSSF工作簿(新文件InputStream(inputFile));
//从工作簿中获取第一张工作表
XSSFSheet sheet=wBook.getSheetAt(0);
行行;
Cell=null;
迭代器rowIterator=sheet.Iterator();
while(roweiterator.hasNext()){
行=行迭代器。下一步();
迭代器cellIterator=row.cellIterator();
while(cellIterator.hasNext()){
cell=cellIterator.next();
开关(cell.getCellType()){
case Cell.Cell\u类型\u布尔值:
data.append(cell.getBooleanCellValue()+“,”);
打破
case Cell.Cell\u类型\u数值:
data.append(cell.getNumericCellValue()+“,”);
打破
case Cell.Cell\u类型\u字符串:
String st=cell.getStringCellValue();
如果(st.contains(“\”)){
st=st.replaceAll(“\”,“);
}
如果(st.contains(“,”)){
st=“\”“+st+”\”;
}
如果(st.contains(“\n”)){
st=st.replaceAll(“\n”和“);
}
数据。追加(st+“,”);
打破
case Cell.Cell\u类型\u空白:
数据。追加(“+”,”);
打破
违约:
数据。追加(单元格+“,”);
}
}
数据。追加(“\n”);
}
fos.write(data.toString().getBytes());
fos.close();
}捕获(异常ioe){
ioe.printStackTrace();
系统输出打印项次(ioe);
}
}
公共静态void main(字符串[]args){
File inputFile=新文件(“D:/test.xlsx”);
File outputFile=新文件(“D:/test.csv”);
xlsx(输入文件,输出文件);
}
}

您可能会得到一个\r字符,您也应该将其替换为空格。
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.FileWriter;
import java.util.Iterator;

import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;

class XlsxtoCSV {

        static void xlsx(File inputFile, File outputFile) {
                // For storing data into CSV files

            //System.out.println("Calling ::::::::::::::::::: method");
                StringBuffer data = new StringBuffer();
                try {
                        FileOutputStream fos = new FileOutputStream(outputFile);

                        // Get the workbook object for XLSX file
               XSSFWorkbook wBook = new XSSFWorkbook(new FileInputStream(inputFile));

                        // Get first sheet from the workbook
                        XSSFSheet sheet = wBook.getSheetAt(0);
                        Row row;
                        Cell cell = null;
                        Iterator<Row> rowIterator = sheet.iterator();

                        while (rowIterator.hasNext()) {
                                row = rowIterator.next();

                                Iterator<Cell> cellIterator = row.cellIterator();
                                while (cellIterator.hasNext()) {

                                        cell = cellIterator.next();



                                        switch (cell.getCellType()) {
                                        case Cell.CELL_TYPE_BOOLEAN:
                                                data.append(cell.getBooleanCellValue() + ",");

                                                break;
                                        case Cell.CELL_TYPE_NUMERIC:
                                                data.append(cell.getNumericCellValue() + ",");

                                                break;
                                        case Cell.CELL_TYPE_STRING:

                                                String st=cell.getStringCellValue();
                                                if(st.contains("\"")) {
                                                    st=st.replaceAll("\"", "");
                                                }
                                                if(st.contains(",")) {
                                                    st="\"" + st + "\"";

                                                }

                                                if(st.contains("\n")) {
                                                    st=st.replaceAll("\n", " ");
                                                }


                                                data.append(st + ",");
                                                break;

                                        case Cell.CELL_TYPE_BLANK:
                                                data.append("" + ",");

                                                break;
                                        default:
                                                data.append(cell + ",");

                                        }
                                }
                                data.append("\n");


                        }

                       fos.write(data.toString().getBytes());
                       fos.close();

                } catch (Exception ioe) {
                        ioe.printStackTrace();
                        System.out.println(ioe);
                }
        }
        public static void main(String[] args) {

            File inputFile = new File("D:/test.xlsx");
            File outputFile = new File("D:/test.csv");
                xlsx(inputFile, outputFile);
        }
}