BeanIO unquotedQuotesAllowed 在 CSV 中不起作用
BeanIO unquotedQuotesAllowed in CSV not working
我想要用分隔符解析文件。我使用 BeanIO 2.1.0。我有一个文件,其中包含一个字符串,其中有一个双引号:
"TEST"/37326330|TEST2
在配置中我设置了参数:
<stream name="csvStream" format="csv">
<parser>
<property name="delimiter" value="|"/>
<property name="unquotedQuotesAllowed" value="true"/>
</parser>
</stream>
但它不起作用!我收到错误:
org.beanio.MalformedRecordException: Malformed record at line 1: Invalid character found outside of quoted field at line 1
但是为什么呢?为什么这个参数不起作用?
我假设您想要 preserve/retain 双引号 ("
)。
unquotedQuotesAllowed
配置选项仅适用于 CSV 流,但根据您的示例测试数据,您使用管道符号 (|
) 作为分隔符。是的,您可以更改 CSV 流的分隔符,但我认为最好只使用配置为 delimited
格式的流映射。 IMO 这更容易使用,您不需要遵守 CSV 格式的所有规则和微妙之处。
然后我会使用以下内容:
<stream name="csvStream" format="delimited">
<parser>
<property name="delimiter" value="|"/>
</parser>
<record name="...">
....
</record>
</stream>
使用上面的映射,我得到以下输出:
Field1: "TEST"/37326330, Field2: TEST2
我想要用分隔符解析文件。我使用 BeanIO 2.1.0。我有一个文件,其中包含一个字符串,其中有一个双引号:
"TEST"/37326330|TEST2
在配置中我设置了参数:
<stream name="csvStream" format="csv">
<parser>
<property name="delimiter" value="|"/>
<property name="unquotedQuotesAllowed" value="true"/>
</parser>
</stream>
但它不起作用!我收到错误:
org.beanio.MalformedRecordException: Malformed record at line 1: Invalid character found outside of quoted field at line 1
但是为什么呢?为什么这个参数不起作用?
我假设您想要 preserve/retain 双引号 ("
)。
unquotedQuotesAllowed
配置选项仅适用于 CSV 流,但根据您的示例测试数据,您使用管道符号 (|
) 作为分隔符。是的,您可以更改 CSV 流的分隔符,但我认为最好只使用配置为 delimited
格式的流映射。 IMO 这更容易使用,您不需要遵守 CSV 格式的所有规则和微妙之处。
然后我会使用以下内容:
<stream name="csvStream" format="delimited">
<parser>
<property name="delimiter" value="|"/>
</parser>
<record name="...">
....
</record>
</stream>
使用上面的映射,我得到以下输出:
Field1: "TEST"/37326330, Field2: TEST2