我正在尝试将json数组存储为在tinkergraph中创建的节点的属性。
public void testnewLine() {
String Value = "[{\n" +
" \"detailAccountType\": 5120,\n" +
" \"name\": \"Ventes dep roduits résiduels en France\",\n" +
" \"id\": 3,\n" +
" \"accountNumber\": \"70301\",\n" +
" \"fullyQualifiedName\": \"Ventes de produits fabriqués, prestations de services, marchandises: Ventes de produits résiduels: Ventes de produits résiduels en France\"\n" +
" }\n" +
"]";
String query = String.format("g.addV('test').property('value', '%s').project('b')", Value);
List<Result> result = helper.getQueryUtils().executeQuery(query);
Assert.assertNotNull(result);
String deleteQuery = "g.V().hasLabel('test').drop()";
helper.getQueryUtils().executeQuery(deleteQuery);
}
我遇到以下错误:
Script5.groovy: 1: expecting ''', found '\n' @ line 1, column 37.
g.addV('test').property('value', '[{
^
答案 0 :(得分:0)
由于使用的是String API发送查询,因此必须对字符转义序列进行两次转义。例如,您可以使用StringEscapeUtils中的Apache Commons Text,但是也可以使用简单的String::replaceAll
:
String query = String.format("g.addV('test').property('value', '%s').project('b')",
Value.replaceAll("[\\r\\n]", "\\\\n"));
但是,在您的特定示例中,最好的解决方案是根本不使用任何换行符,因为它们除了使JSON Blob看起来更人眼外没有其他目的。我可能更喜欢用单个空格替换任何空格序列:
Value.replaceAll("[\\r\\n\\t ]+", " ")
仅当JSON blob中的值使用这些字符和/或转义序列中的任何一个时,这才成为问题。在这种情况下,两次转义是您唯一的选择。