java - 如何使用 Java 将 CSV 的空单元格替换为 NULL 文本

标签 java csv

我输入了 CSV。其中一列在单元格中没有值。将数据写入另一个 CSV 时,我想在该空单元格中写入 NULL。 我尝试用 NULL 替换“”,但随后它在所有单元格中打印 NULL。 另外,我想排除在代码的硬编码列中添加 NULL 文本,即 UniqueId、IsDelete、Rootpid。我希望它们是空的。

Input Expected Output

这是迄今为止我的代码:

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


        String sourceFilePath = "C://MyData/Emp_Input.csv";
        String newFilePath = "C://MyData/Emp_Output.csv";
        File sourceCsvFile = new File(sourceFilePath);
        File finalCsvFile = new File(newFilePath);
        final Charset Encoding = Charset.forName("UTF-8"); 
        String cvsSplitBy = ",";


        String line = "";

        BufferedWriter writer = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(finalCsvFile), Encoding));


        try (BufferedReader br = new BufferedReader(new FileReader(sourceCsvFile))) 
        {
            line = br.readLine(); 
            String newFileLine = "UniqueID" + cvsSplitBy +line + cvsSplitBy  + "IsDelete" + cvsSplitBy + "Rootpid";
            writer.write(newFileLine);   
            writer.newLine();


            while ((line = br.readLine()) != null)  
            {   
            /*  if (line.contains("") )
                {

                    line = line.replace("", "NULL"); // missing code to replace empty cell of a csv with text as NULL
                } */


                else if (line.contains("TRUE") || line.contains("FALSE"))
                {
                    line = line.replace("TRUE", "1");
                    line = line.replace("FALSE", "0");

                } 


                    newFileLine =  cvsSplitBy + line + cvsSplitBy + cvsSplitBy;
                    writer.write(newFileLine);  
                    writer.newLine();


            }

            writer.close();

        }


    }

最佳答案

不可能,csv中的空字符串和空字符串没有区别。

关于java - 如何使用 Java 将 CSV 的空单元格替换为 NULL 文本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53685991/

相关文章:

javascript - 试图制作可重用的 javascript 函数,但数据没有返回

python - 处理 csv 文件中的 header 时遇到问题

c# - 分离excel多行选择

java - 使用 SimpleDateFormat 解析日期

java - Eclipse 继续运行该类但不打印任何内容

java - 两个实体上的 JPA/Hibernate 双向 Set<Object>

java - 将方法添加到 Java 8 Stream

python - 从 CSV 文件中计算男性和女性的数量

java - 删除 "final"关键字会影响二进制兼容性吗?

php - 如何在有条件的情况下使用PHP将csv文件解析为mysql DB