如何从Java arraylist中消除空csv记录?

如何从Java arraylist中消除空csv记录?,java,csv,arraylist,Java,Csv,Arraylist,我有一个需求,我需要获取一些值,然后将所有这些值写入csv文件。为了实现这一点,我将这些值添加到JavaArrayList并写入csv文件。但当我这样做时,它会将记录写入CSV,但记录之间有空行。不知道为什么会出现这个问题 1,abc,fname,lname,email,log 1,abc1,fname1,lname1,email1,log1 1,abc2,fname2,lname2,email2,log2 1,abc3,fname3,lname3,email3,log3 1,abc4,

我有一个需求,我需要获取一些值,然后将所有这些值写入csv文件。为了实现这一点,我将这些值添加到JavaArrayList并写入csv文件。但当我这样做时,它会将记录写入CSV,但记录之间有空行。不知道为什么会出现这个问题

1,abc,fname,lname,email,log


1,abc1,fname1,lname1,email1,log1
1,abc2,fname2,lname2,email2,log2


1,abc3,fname3,lname3,email3,log3
1,abc4,fname4,lname4,email4,log4
这是我的密码。请让我知道此代码有什么问题:

public StringBuilder fetchUsers() {
    ArrayList<String> users = null;
    StringBuilder sb1 = new StringBuilder();
    try {
        client = getMyClient();
        if (client != null) {
            UserList usersList = getUsers();
            if (usersList.totalCount != 0 && usersList.totalCount >= 1) {
                System.out.println("usersList.totalCount ----->"
                        + usersList.totalCount);

                for (KalturaUser user : usersList.objects) {
                    users = new ArrayList<String>();
                    if (user != null) {
                        String action = null;
                        String userFullName = null;
                        String modifiedName = null;
                        String firstName = user.firstName;
                        if (user.id != null) {
                            String cnum = getUserUniqueId(user.id);
                            String userRole = getUserRole(user.id);
                            if (cnum != null || userRole != null) {
                                action = validateCnum(cnum, userRole);
                                if (!action.equals("3")) {
                                    users.add(action);
                                    users.add(cnum);
                                    if (firstName != null
                                            && firstName.contains("@")) {
                                        user.email = firstName;
                                        userFullName = getUserNames(user.id);
                                        firstName = userFullName;
                                    }
                                    users.add(firstName);
                                    users.add(user.lastName);
                                    users.add(user.email);
                                    users.add(userRole);
                                }
                            }
                        }
                    }
                    allUsers.add(users);
                }
            }
        }
    } catch (MyException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    } catch (IOException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    } catch (ParserConfigurationException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    } catch (SAXException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }
    writeToCSV();
    return sb1;
}


private void writeToCSV() {
    FileWriter fileWriter = null;
    CSVPrinter csvFilePrinter = null;
    CSVFormat csvFileFormat = CSVFormat.DEFAULT.withRecordSeparator(System
            .getProperty("line.separator"));
    try {
        fileWriter = new FileWriter("C:/users.csv");
        csvFilePrinter = new CSVPrinter(fileWriter, csvFileFormat);
        csvFilePrinter.printRecord(USER_COLUMNS);
        for (List<String> rowData : allUsers) {
            csvFilePrinter.printRecord(rowData);
        }
    } catch (Exception e) {
        logger.error(e.getStackTrace());
    } finally {
        try {
            fileWriter.flush();
            fileWriter.close();
            csvFilePrinter.close();
        } catch (IOException e) {
            logger.error("Error while flushing/closing fileWriter/csvPrinter!");
            }
    }
}
publicstringbuilderfetchusers(){
ArrayList用户=null;
StringBuilder sb1=新的StringBuilder();
试一试{
client=getMyClient();
如果(客户端!=null){
UserList usersList=getUsers();
如果(usersList.totalCount!=0&&usersList.totalCount>=1){
System.out.println(“usersList.totalCount------>”
+usersList.totalCount);
for(用户:usersList.objects){
users=newarraylist();
如果(用户!=null){
字符串操作=null;
字符串userFullName=null;
字符串modifiedName=null;
字符串firstName=user.firstName;
如果(user.id!=null){
字符串cnum=getUserUniqueId(user.id);
字符串userRole=getUserRole(user.id);
if(cnum!=null | | userRole!=null){
action=validateCnum(cnum,userRole);
如果(!action.equals(“3”)){
用户。添加(操作);
用户。添加(cnum);
if(firstName!=null
&&firstName.contains(“@”)){
user.email=firstName;
userFullName=getUserNames(user.id);
firstName=userFullName;
}
users.add(firstName);
users.add(user.lastName);
users.add(user.email);
添加(userRole);
}
}
}
}
添加(用户);
}
}
}
}捕获(MyException e){
//TODO自动生成的捕捉块
e、 printStackTrace();
}捕获(IOE异常){
//TODO自动生成的捕捉块
e、 printStackTrace();
}捕获(ParserConfiguration异常e){
//TODO自动生成的捕捉块
e、 printStackTrace();
}捕获(SAXE异常){
//TODO自动生成的捕捉块
e、 printStackTrace();
}
writeToCSV();
返回sb1;
}
私有void writeToCSV(){
FileWriter FileWriter=null;
CSVPrinter csvFilePrinter=null;
CSVFormat csvFileFormat=CSVFormat.DEFAULT.withRecordSeparator(系统
.getProperty(“line.separator”);
试一试{
fileWriter=新的fileWriter(“C:/users.csv”);
csvFilePrinter=新的CSVPrinter(fileWriter,csvFileFormat);
打印记录(用户列);
对于(列表行数据:allUsers){
csvFilePrinter.printRecord(行数据);
}
}捕获(例外e){
logger.error(例如getStackTrace());
}最后{
试一试{
fileWriter.flush();
fileWriter.close();
csvFilePrinter.close();
}捕获(IOE异常){
logger.error(“刷新/关闭fileWriter/csvPrinter时出错!”);
}
}
}
这是:

 allUsers.add(users);
应位于
if(user!=null)
和所有子if内

大概是这样的:

if (user != null) {
...
    if (user.id != null) {

        ...
        if (cnum != null || userRole != null) {
            ....
            if (!action.equals("3")) {
                users = new ArrayList<String>();
                ....
                allUsers.add(users);
            }
        }
    }
}
if(用户!=null){
...
如果(user.id!=null){
...
if(cnum!=null | | userRole!=null){
....
如果(!action.equals(“3”)){
users=newarraylist();
....
添加(用户);
}
}
}
}

通常,只有在需要添加内容时,才应创建数组并将其添加到
alluser
,这就是问题所在。从代码中我只感觉到了这个问题。@Roman-我已经应用了您提到的更改。但是还是一样的问题。你已经把它放在
if(!action.equals(“3”))
?@Roman中了-非常感谢。现在它开始工作了。我也理解这个概念。非常感谢Stack exchange在工作中学习了很多东西。