1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17 package org.apache.commons.text.translate;
18
19 import java.io.IOException;
20 import java.io.Writer;
21
22 import org.apache.commons.lang3.CharUtils;
23 import org.apache.commons.lang3.StringUtils;
24
25
26
27
28
29
30
31
32
33
34 public final class CsvTranslators {
35
36
37
38
39 public static class CsvEscaper extends SinglePassTranslator {
40
41
42
43
44 public CsvEscaper() {
45
46 }
47
48 @Override
49 void translateWhole(final CharSequence input, final Writer writer) throws IOException {
50 final String inputSting = input.toString();
51 if (StringUtils.containsNone(inputSting, CSV_SEARCH_CHARS)) {
52 writer.write(inputSting);
53 } else {
54
55 writer.write(CSV_QUOTE);
56 writer.write(StringUtils.replace(inputSting, CSV_QUOTE_STR, CSV_ESCAPED_QUOTE_STR));
57 writer.write(CSV_QUOTE);
58 }
59 }
60 }
61
62
63
64 public static class CsvUnescaper extends SinglePassTranslator {
65
66
67
68
69 public CsvUnescaper() {
70
71 }
72
73 @Override
74 void translateWhole(final CharSequence input, final Writer writer) throws IOException {
75
76 if (input.charAt(0) != CSV_QUOTE || input.charAt(input.length() - 1) != CSV_QUOTE) {
77 writer.write(input.toString());
78 return;
79 }
80
81
82 final String quoteless = input.subSequence(1, input.length() - 1).toString();
83
84 if (StringUtils.containsAny(quoteless, CSV_SEARCH_CHARS)) {
85
86 writer.write(StringUtils.replace(quoteless, CSV_ESCAPED_QUOTE_STR, CSV_QUOTE_STR));
87 } else {
88 writer.write(quoteless);
89 }
90 }
91 }
92
93 private static final char CSV_DELIMITER = ',';
94
95 private static final char CSV_QUOTE = '"';
96
97 private static final String CSV_QUOTE_STR = String.valueOf(CSV_QUOTE);
98
99
100 private static final String CSV_ESCAPED_QUOTE_STR = CSV_QUOTE_STR + CSV_QUOTE_STR;
101
102
103 private static final char[] CSV_SEARCH_CHARS = { CSV_DELIMITER, CSV_QUOTE, CharUtils.CR, CharUtils.LF };
104
105
106 private CsvTranslators() {
107
108 }
109 }