[英]Java split string with RegexOption.MULTILINE
I want to split for example the following Sql statements by semi-colon end of line: 我想用分号结尾的示例拆分以下Sql语句:
CREATE TABLE projects(
id INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL,
name TEXT NOT NULL,
created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP
);
CREATE INDEX ix_tasks_project_id ON tasks (project_id);
SELECT * FROM projects WHERE name = "someName;WithSemiColon";
Something like: string.split(";$");
类似于: string.split(";$");
(but with RegexOption.MULTILINE
applied) (但使用RegexOption.MULTILINE
)
Can someone please explain how do I apply the RegexOption
? 有人可以解释我如何应用RegexOption
吗?
Simply prefix your regular expression with (?m)
to enable the flag MULTILINE
so in your case it would be (?m);$
只需在正则表达式前面加上(?m)
即可启用标志MULTILINE
因此在您的情况下为(?m);$
for (String s : string.split("(?m);$")) {
System.out.printf("----> %s%n", s.trim());
}
Output: 输出:
----> CREATE TABLE projects(
id INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL,
name TEXT NOT NULL,
created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP
)
----> CREATE INDEX ix_tasks_project_id ON tasks (project_id)
----> SELECT * FROM projects WHERE name = "someName;WithSemiColon"
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.