我有这个功能(将代码示例的HTML标记剥离)从CSV构建HTML表,但是每次尝试运行它时都会遇到运行时错误,但我不知道为什么。谷歌说,也许编码有些错误,但是我不知道如何更改。
我的CSV以ANSI编码,并包含ä,Ä,Ü,Ö等字符,但我无法控制编码,或者将来是否会更改。
错误发生在这里:
Caused by: java.io.UncheckedIOException: java.nio.charset.MalformedInputException: Input length = 1 at java.io.BufferedReader$1.hasNext(Unknown Source) at java.util.Iterator.forEachRemaining(Unknown Source) at java.util.Spliterators$IteratorSpliterator.forEachRemaining(Unknown Source) at java.util.stream.ReferencePipeline$Head.forEach(Unknown Source) at testgui.Csv2Html.start(Csv2Html.java:121)
121行是
lines.forEach(line -> {
源代码:
protected void start() throws Exception { Path path = Paths.get(inputFile); FileOutputStream fos = new FileOutputStream(outputFile, true); PrintStream ps = new PrintStream(fos); boolean withTableHeader = (inputFile.length() != 0); try { Stream<String> lines = Files.lines(path); lines.forEach(line -> { try { String[] columns = line.split(";"); for (int i=0; i<columns.length; i++) { columns[i] = escapeHTMLChars(columns[i]); } if (withTableHeader == true && firstLine == true) { tableHeader(ps, columns); firstLine = false; } else { tableRow(ps, columns); } } catch (Exception e) { e.printStackTrace(); } finally { } }); } finally { ps.close(); } }
您可以尝试通过使用方法(javadocs)的Files.lines(Path path, Charset charset)形式来利用正确的编码。lines
Files.lines(Path path, Charset charset)
lines
这是受支持的编码的列表(无论如何适用于Oracle JVM)。 这篇文章表明“ Cp1252”是Windows ANSI。