Как экспортировать файл CSV в Struts2 - PullRequest
0 голосов
/ 25 июня 2019

Я экспортирую файл .xlsx и теперь хочу экспортировать файл .csv.

Я пытался найти решение для этого, но я думаю, что ни один из них не подходит для моей ситуации.

Ниже мои коды

Отображение действий:

<action name="export" class="com.xxx.xxx.xxx.action.myAction" method="excel">
    <result type="excel">
        <param name="template">/xlsTemplate/excel_temaplate.xls</param>
        <param name="beans">gridModel</param>
        <param name="filenameKey">filename</param>
    </result>
</action>

Действие:

public String excel() {
        ArrayList<MyVo> resultList = myService.myFunction();
        setGridModel(resultList);
        return SUCCESS;
    }catch(Exception e){
        return ERROR;
    }
}

Это хорошо работает, и я пытаюсь экспортировать файл .csv вместо файла .xlsx для веб-страниц (не сохраняя локально), чтобы пользователи могли его скачать.

С чего мне начать?

Любой комментарий будет оценен. Спасибо.

1 Ответ

0 голосов
/ 25 июня 2019

Вот класс утилит для управления CSV:


import java.io.IOException;
import java.io.Writer;
import java.util.List;

public class CSVUtils {

    private static final char DEFAULT_SEPARATOR = ',';

    public static void writeLine(Writer w, List<String> values) throws IOException {
        writeLine(w, values, DEFAULT_SEPARATOR, ' ');
    }

    public static void writeLine(Writer w, List<String> values, char separators) throws IOException {
        writeLine(w, values, separators, ' ');
    }

    //https://tools.ietf.org/html/rfc4180
    private static String followCVSformat(String value) {

        String result = value;
        if (result.contains("\"")) {
            result = result.replace("\"", "\"\"");
        }
        return result;

    }

    public static void writeLine(Writer w, List<String> values, char separators, char customQuote) throws IOException {

        boolean first = true;

        //default customQuote is empty

        if (separators == ' ') {
            separators = DEFAULT_SEPARATOR;
        }

        StringBuilder sb = new StringBuilder();
        for (String value : values) {
            if (!first) {
                sb.append(separators);
            }
            if (customQuote == ' ') {
                sb.append(followCVSformat(value));
            } else {
                sb.append(customQuote).append(followCVSformat(value)).append(customQuote);
            }

            first = false;
        }
        sb.append("\n");
        w.append(sb.toString());


    }

}

То есть вы используете его в своем коде как:

    public String excel() throws Exception{
        String csvFile = "/Users/mkyong/csv/abc.csv";
        FileWriter writer = new FileWriter(csvFile);
        ArrayList<MyVo> resultList = myService.myFunction();
        List<String> strings = resultList.stream()
       .map(obj -> obj.getYourAttr())
       .collect(Collectors.toList());
        CSVUtils.writeLine(writer, strings);
       writer.flush();
        writer.close();

        return SUCCESS;
        }catch(Exception e){
            return ERROR;
        }
    }

...