电子商务网站cms,南海网站建设报价,深圳市建筑工程,网络推广的方法你知道几个?QUESTION
博主在进行华为杯的人工智能比赛中#xff0c;要做的题目需要对json格式的数据进行选取#xff0c;虽然说 “人生苦短#xff0c;我用python”#xff0c;但这也只是自嘲。用Java选取大json更方便。在写代码的时候#xff0c;就遇到了如何使用正则表达式对字符串…QUESTION
博主在进行华为杯的人工智能比赛中要做的题目需要对json格式的数据进行选取虽然说 “人生苦短我用python”但这也只是自嘲。用Java选取大json更方便。在写代码的时候就遇到了如何使用正则表达式对字符串进行选取。 ANSWER 在寻找网上的文章时也看到了许多大佬们写的博客在此感谢大佬们。 如何用在一个字符串中换行 Testpublic void substring() {String string {\text\:\New pictures from Ironman Hawaii and XTerra Maui online!\\nPictures from Ironman Hawaii are online!\\nThe SuperSeal Triathlon (1.5K ocean swim, 40K bike, 10K run) took place on Coronado Island, just off the coast of San Diego, California yesterday morning. The race featured a cold ocean swim, an exposed and windy bike course, followed by a soft sand and pavement run route.\,\timestamp\:\2019-04-20T02:21:16Z\,\url\:\http://michiweiss.at/stories-pid386\};String s StringUtils.substringBetween(string, {\text\:\, \,\timestamp\);String aaa s.replaceAll(\\\\n, \n);System.out.println(s);System.out.println(aaa);}常用正则表达式
首先博主一开始也是迷惑是不是正则表达式在c、Java、python中都是相似的呢
各位往下看其实是不然的。
正则表达式定义了字符串的模式。
正则表达式可以用来搜索、编辑或处理文本。
正则表达式并不仅限于某一种语言但是在每种语言中有细微的差别。 一个字符串其实就是一个简单的正则表达式例如 Hello World 正则表达式匹配 Hello World 字符串。
在其他语言中\\ 表示我想要在正则表达式中插入一个普通的字面上的反斜杠请不要给它任何特殊的意义。
在 Java 中\\ 表示我要插入一个正则表达式的反斜线所以其后的字符具有特殊的意义。
所以在其他的语言中如 Perl一个反斜杠 \ 就足以具有转义的作用而在 Java 中正则表达式中则需要有两个反斜杠才能被解析为其他语言中的转义作用。也可以简单的理解在 Java 的正则表达式中两个 \\ 代表其他语言中的一个 \这也就是为什么表示一位数字的正则表达式是 \\d而表示一个普通的反斜杠是 \\。 字符 说明 \ 将下一字符标记为特殊字符、文本、反向引用或八进制转义符。例如 n匹配字符 n。\n 匹配换行符。序列 \\\\ 匹配 \\ \\( 匹配 (。 ^ 匹配输入字符串开始的位置。如果设置了 RegExp 对象的 Multiline 属性^ 还会与\n或\r之后的位置匹配。 $ 匹配输入字符串结尾的位置。如果设置了 RegExp 对象的 Multiline 属性$ 还会与\n或\r之前的位置匹配。 * 零次或多次匹配前面的字符或子表达式。例如zo* 匹配z和zoo。* 等效于 {0,}。 一次或多次匹配前面的字符或子表达式。例如zo与zo和zoo匹配但与z不匹配。 等效于 {1,}。 ? 零次或一次匹配前面的字符或子表达式。例如do(es)?匹配do或does中的do。? 等效于 {0,1}。 {n} n 是非负整数。正好匹配 n 次。例如o{2}与Bob中的o不匹配但与food中的两个o匹配。 {n,} n 是非负整数。至少匹配 n 次。例如o{2,}不匹配Bob中的o而匹配foooood中的所有 o。o{1,}等效于o。o{0,}等效于o*。 {n,m} m 和 n 是非负整数其中 n m。匹配至少 n 次至多 m 次。例如o{1,3}匹配fooooood中的头三个 o。o{0,1} 等效于 o?。注意您不能将空格插入逗号和数字之间。 ? 当此字符紧随任何其他限定符*、、?、{n}、{n,}、{n,m}之后时匹配模式是非贪心的。非贪心的模式匹配搜索到的、尽可能短的字符串而默认的贪心的模式匹配搜索到的、尽可能长的字符串。例如在字符串oooo中o?只匹配单个o而o匹配所有o。 . 匹配除\r\n之外的任何单个字符。若要匹配包括\r\n在内的任意字符请使用诸如[\s\S]之类的模式。 (pattern) 匹配 pattern 并捕获该匹配的子表达式。可以使用 $0…$9 属性从结果匹配集合中检索捕获的匹配。若要匹配括号字符 ( )请使用\(或者\)。 (?:pattern) 匹配 pattern 但不捕获该匹配的子表达式即它是一个非捕获匹配不存储供以后使用的匹配。这对于用or字符 (|) 组合模式部件的情况很有用。例如industr(?:y|ies) 是比 industry|industries 更经济的表达式。 (?pattern) 执行正向预测先行搜索的子表达式该表达式匹配处于匹配 pattern 的字符串的起始点的字符串。它是一个非捕获匹配即不能捕获供以后使用的匹配。例如Windows (?95|98|NT|2000) 匹配Windows 2000中的Windows但不匹配Windows 3.1中的Windows。预测先行不占用字符即发生匹配后下一匹配的搜索紧随上一匹配之后而不是在组成预测先行的字符后。 (?!pattern) 执行反向预测先行搜索的子表达式该表达式匹配不处于匹配 pattern 的字符串的起始点的搜索字符串。它是一个非捕获匹配即不能捕获供以后使用的匹配。例如Windows (?!95|98|NT|2000) 匹配Windows 3.1中的 Windows但不匹配Windows 2000中的Windows。预测先行不占用字符即发生匹配后下一匹配的搜索紧随上一匹配之后而不是在组成预测先行的字符后。 x|y 匹配 x 或 y。例如z|food 匹配z或food。(z|f)ood 匹配zood或food。 [xyz] 字符集。匹配包含的任一字符。例如[abc]匹配plain中的a。 [^xyz] 反向字符集。匹配未包含的任何字符。例如[^abc]匹配plain中plin。 [a-z] 字符范围。匹配指定范围内的任何字符。例如[a-z]匹配a到z范围内的任何小写字母。 [^a-z] 反向范围字符。匹配不在指定的范围内的任何字符。例如[^a-z]匹配任何不在a到z范围内的任何字符。 \b 匹配一个字边界即字与空格间的位置。例如er\b匹配never中的er但不匹配verb中的er。 \B 非字边界匹配。er\B匹配verb中的er但不匹配never中的er。 \cx 匹配 x 指示的控制字符。例如\cM 匹配 Control-M 或回车符。x 的值必须在 A-Z 或 a-z 之间。如果不是这样则假定 c 就是c字符本身。 \d 数字字符匹配。等效于 [0-9]。 \D 非数字字符匹配。等效于 [^0-9]。 \f 换页符匹配。等效于 \x0c 和 \cL。 \n 换行符匹配。等效于 \x0a 和 \cJ。 \r 匹配一个回车符。等效于 \x0d 和 \cM。 \s 匹配任何空白字符包括空格、制表符、换页符等。与 [ \f\n\r\t\v] 等效。 \S 匹配任何非空白字符。与 [^ \f\n\r\t\v] 等效。 \t 制表符匹配。与 \x09 和 \cI 等效。 \v 垂直制表符匹配。与 \x0b 和 \cK 等效。 \w 匹配任何字类字符包括下划线。与[A-Za-z0-9_]等效。 \W 与任何非单词字符匹配。与[^A-Za-z0-9_]等效。 \xn 匹配 n此处的 n 是一个十六进制转义码。十六进制转义码必须正好是两位数长。例如\x41匹配A。\x041与\x041等效。允许在正则表达式中使用 ASCII 代码。 \num 匹配 num此处的 num 是一个正整数。到捕获匹配的反向引用。例如(.)\1匹配两个连续的相同字符。 \n 标识一个八进制转义码或反向引用。如果 \n 前面至少有 n 个捕获子表达式那么 n 是反向引用。否则如果 n 是八进制数 (0-7)那么 n 是八进制转义码。 \nm 标识一个八进制转义码或反向引用。如果 \nm 前面至少有 nm 个捕获子表达式那么 nm 是反向引用。如果 \nm 前面至少有 n 个捕获则 n 是反向引用后面跟有字符 m。如果两种前面的情况都不存在则 \nm 匹配八进制值 nm其中 n 和 m 是八进制数字 (0-7)。 \nml 当 n 是八进制数 (0-3)m 和 l 是八进制数 (0-7) 时匹配八进制转义码 nml。 \un 匹配 n其中 n 是以四位十六进制数表示的 Unicode 字符。例如\u00A9 匹配版权符号 (©)。
介绍常用的用法
replaceFirst 和 replaceAll 方法用来替换匹配正则表达式的文本。不同的是replaceFirst 替换首次匹配replaceAll 替换所有匹配。
// 按指定模式在字符串查找String line This order was placed for QT3000! OK?;String pattern (\\D*)(\\d)(.*);// 创建 Pattern 对象Pattern r Pattern.compile(pattern);// 现在创建 matcher 对象Matcher m r.matcher(line);if (m.find( )) {System.out.println(Found value: m.group(0) );System.out.println(Found value: m.group(1) );System.out.println(Found value: m.group(2) );System.out.println(Found value: m.group(3) ); } else {System.out.println(NO MATCH); 如果感到有用请点击关注和点赞一起进步呀