描述
开 本: 16开纸 张: 胶版纸包 装: 平装-胶订是否套装: 否国际标准书号ISBN: 9787121351303
√ 覆盖所有主流编程语言及其版本差异
√ 源代码及文本数据处理走向高效之路
√ 贯通编码问题→匹配原理→解题思路
√ 适用日志分析|网络运维|自动化测试
√ 深入原理结构差异以利现成成果移植
第1章 字符组 ……………..2
1.1 普通字符组 …………. 2
1.2 关于Python的基础知识……………………… 4
1.3 普通字符组(续) . 6
1.4 元字符与转义 ……… 8
1.5 排除型字符组 ……. 10
1.6 字符组简记法 ……. 12
1.7 字符组运算 ……….. 14
1.8 POSIX字符组 …… 15
第2章 量词 ……………….17
2.1 一般形式 …………… 17
2.2 常用量词 …………… 19
2.3 数据提取 …………… 21
2.4 点号………………….. 23
2.5 滥用点号的问题 … 23
2.6 忽略优先量词 ……. 26
2.7 转义………………….. 31
第3章 括号 ……………….33
3.1 分组………………….. 33
3.2 多选结构 …………… 39
3.3 引用分组 …………… 44
3.3.1 反向引用… 48
3.3.2 各种引用的记法 …………………….. 50
3.3.3 命名分组… 53
3.4 非捕获分组 ……….. 55
3.5 补充………………….. 56
3.5.1 转义 ………. 56
3.5.2 URL Rewrite ………………………….. 56
3.5.3 一个例子… 58
第4章 断言 ……………….60
4.1 单词边界 …………… 60
4.2 行起始/结束位置 .. 62
4.3 环视………………….. 69
4.4 补充………………….. 75
4.4.1 环视的价值 ……………………………. 75
4.4.2 环视与分组编号 …………………….. 76
4.4.3 环视的支持程度 …………………….. 77
4.4.4 环视的组合 ……………………………. 79
4.4.5 断言和反向引用之间的关系 …… 81
4.4.6 逆序环视的诡异之处 ……………… 81
第5章 匹配模式 …………83
5.1 不区分大小写模式与模式的指定方式 .. 83
5.2 单行模式 …………… 86
5.3 多行模式 …………… 87
5.4 注释模式 …………… 89
5.5 补充………………….. 91
5.5.1 更多的模式 ……………………………. 91
5.5.2 修饰符的作用范围 …………………. 91
5.5.3 失效修饰符 ……………………………. 92
5.5.4 模式与反向引用 …………………….. 93
5.5.5 冲突策略… 93
5.5.6 哪种方式更好 ………………………… 94
第6章 其他 ……………….95
6.1 转义………………….. 95
6.1.1 字符串转义与正则转义 ………….. 95
6.1.2 元字符的转义 ………………………… 99
6.1.3 彻底消除元字符的特殊含义 …. 101
6.2.1 函数式处理 ………………………….. 104
6.2.2 面向对象式处理 …………………… 104
6.2.3 比较 …….. 105
6.2.4 线程安全性 ………………………….. 106
6.3 表达式中的优先级 ………………………….. 108
6.4 回车和换行 ……… 109
第二部分
第7章 Unicode ………..112
7.1 基础知识 …………. 112
7.2 关于编码 …………. 115
7.3 尽量使用Unicode编码 …………………… 116
7.4 Unicode与字符组简记法 ………………… 120
7.5 规范化问题 ……… 122
7.6 单词边界 …………. 123
7.7 码值转义序列 ….. 125
7.8 Unicode属性 …… 127
7.8.1 Unicode Property ………………….. 128
7.8.2 Unicode Block ……………………… 128
7.8.3 Unicode Script ……………………… 129
7.9 Unicode属性列表 …………………………… 130
7.9.1 Unicode Property ………………….. 130
7.9.2 Unicode Block ……………………… 131
7.9.3 Unicode Script ……………………… 135
7.10 POSIX字符组 .. 135
7.11 Emoji …………….. 136
第8章 匹配原理 ……….138
8.1 有穷自动机 ……… 138
8.2 正则表达式的匹配过程 …………………… 139
8.3 回溯………………… 142
8.4 NFA和DFA ……. 144
9.1 关于元素的三种逻辑 ………………………. 146
9.1.1 必须出现. 147
9.1.2 可能出现. 147
9.1.3 不能出现. 148
9.2 正则表达式的常见操作 …………………… 150
9.2.1 提取 …….. 150
9.2.2 验证 …….. 156
9.2.3 替换 …….. 160
9.2.4 切分 …….. 165
9.3 正则表达式的优化建议 …………………… 167
9.3.1 使用缓存. 167
9.3.2 尽量准确地表达意图 ……………. 168
9.3.3 避免重复匹配 ………………………. 168
9.3.4 独立出文本和锚点 ……………….. 169
9.4 别过分依赖正则表达式 …………………… 170
9.4.1 彻底放弃字符串操作 ……………. 170
9.4.2 思维定式. 171
9.4.3 正则表达式可以匹配各种文本 172
9.4.4 滥用正则表达式 …………………… 173
第三部分
第10章 .NET …………..176
10.1 预备知识 ……….. 176
10.2 正则功能详解 … 177
10.2.1 列表 …. 177
10.2.2 字符组 178
10.2.3 Unicode属性 ……………………. 178
10.2.4 字符组简记法…………………… 179
10.2.5 单词边界 …………………………. 179
10.2.6 行起始/结束位置 ……………… 180
10.2.7 环视 …. 181
10.2.8 匹配模式 …………………………. 181
10.2.9 捕获分组的引用 ……………….. 182
10.3.1 Regex .. 183
10.3.2 Match .. 187
10.4 常用操作示例 … 188
10.4.1 验证 …. 188
10.4.2 提取 …. 189
10.4.3 替换 …. 189
10.4.4 切分 …. 190
第11章 Java …………..191
11.1 预备知识 ……….. 191
11.2 正则功能详解 … 192
11.2.1 列表 …. 192
11.2.2 字符组. 192
11.2.3 Unicode属性 ……………………. 194
11.2.4 字符组简记法 …………………… 194
11.2.5 单词边界 ………………………….. 194
11.2.6 行起始/结束位置 ………………. 195
11.2.7 环视 …. 196
11.2.8 匹配模式 ………………………….. 196
11.2.9 纯文本模式 ………………………. 197
11.2.10 捕获分组的引用 ……………… 197
11.3 正则API简介 .. 197
11.3.1 Pattern . 198
11.3.2 Matcher ……………………………. 200
11.3.3 String … 203
11.4 常用操作示例 … 204
11.4.1 验证 …. 204
11.4.2 提取 …. 204
11.4.3 替换 …. 205
11.4.4 切分 …. 206
11.5 Java 8和Java 9的新改进 ………………. 206
11.5.1 Java 8的新改进 ………………… 206
11.5.2 Java 9的新改进 ………………… 207
12.1 预备知识 ……….. 208
12.2 正则功能详解 … 209
12.2.1 列表 …. 209
12.2.2 字符组 210
12.2.3 字符组简记法…………………… 211
12.2.4 单词边界 …………………………. 211
12.2.5 行起始/结束位置 ……………… 212
12.2.6 环视 …. 212
12.2.7 匹配模式 …………………………. 213
12.2.8 捕获分组的引用 ……………….. 214
12.3 正则API简介 .. 215
12.3.1 RegExp 215
12.3.2 String … 218
12.4 常用操作示例 … 221
12.4.1 验证 …. 221
12.4.2 提取 …. 222
12.4.3 替换 …. 223
12.4.4 切分 …. 223
12.5 关于ActionScript ………………………….. 223
12.5.1 RegExp 223
12.5.2 匹配规则 …………………………. 224
12.5.3 匹配模式 …………………………. 224
12.5.4 正则API ………………………….. 224
第13章 PHP ……………225
13.1 预备知识 ……….. 225
13.2 正则功能详解 … 227
13.2.1 列表 …. 227
13.2.2 字符组 228
13.2.3 Unicode属性 ……………………. 229
13.2.4 字符组简记法…………………… 229
13.2.5 单词边界 …………………………. 230
13.2.6 行起始/结束位置 ……………… 230
13.2.7 环视 …. 231
13.2.8 匹配模式 …………………………. 231
13.2.10 捕获分组的引用 ……………… 232
13.3 正则API简介 .. 233
13.3.1 PREG 常量说明 ………………. 233
13.3.2 preg_quote ……………………….. 235
13.3.3 preg_ grep ………………………… 235
13.3.4 preg_match ……………………….. 236
13.3.5 preg_match_all ………………….. 237
13.3.6 preg_last_error ………………….. 239
13.3.7 preg_replace ……………………… 239
13.3.8 preg_replace_callback ………… 240
13.3.9 preg_filter …………………………. 240
13.3.10 preg_split ……………………….. 241
13.3.11 preg_replace_callback_array 242
13.4 常见的正则操作举例 …………………….. 243
13.4.1 验证 …. 243
13.4.2 提取 …. 243
13.4.3 替换 …. 244
13.4.4 切分 …. 244
第14章 Python ………..245
14.1 预备知识 ……….. 245
14.2 正则功能详解 … 246
14.2.1 列表 …. 246
14.2.2 字符组 247
14.2.3 Unicode属性 ……………………. 248
14.2.4 字符组简记法…………………… 249
14.2.5 单词边界 …………………………. 250
14.2.6 行起始/结束位置 ……………… 251
14.2.7 环视 …. 252
14.2.8 匹配模式 …………………………. 252
14.2.9 捕获分组的引用 ……………….. 253
14.2.10 条件匹配 ……………………….. 253
14.3 正则API简介 .. 254
14.3.1 RegexObject ……………………… 254
14.3.2 re.compile(regex[, flags]) ……. 255
14.3.4 MatchObject ……………………… 256
14.3.5 re.match(pattern, string[, flags]) ………………………….. 257
14.3.6 re.findall(pattern, string[, flags]) …………………………. 258
14.3.7 re.finditer(pattern, string[, flags]) ………………………… 258
14.3.8 re.split(pattern, string[, maxsplit=0, flags=0]) ………. 259
14.3.9 re.sub(pattern, repl, string[, count, flags]) …………….. 259
14.4 常用操作示例 … 260
14.4.1 验证 …. 260
14.4.2 提取 …. 261
14.4.3 替换 …. 262
14.4.4 切分 …. 262
第15章 Ruby …………..263
15.1 预备知识 ……….. 263
15.2 正则功能详解 … 264
15.2.1 列表 …. 264
15.2.2 字符组 264
15.2.3 Unicode属性 ……………………. 265
15.2.4 字符组简记法…………………… 266
15.2.5 单词边界 …………………………. 266
15.2.6 行起始/结束位置 ……………… 267
15.2.7 环视 …. 268
15.2.8 匹配模式 …………………………. 268
15.2.9 捕获分组的引用 ……………….. 269
15.3 正则API简介 .. 269
15.3.1 Regexp 269
15.3.2 Regexp.match(text) ……………. 271
15.3.3 Regexp.quote(text)和Regexp.escape(text) …………… 272
15.3.4 String.index(Regexp) …………. 273
15.3.5 String.scan(Regexp) …………… 273
15.3.6 String.slice(Regexp) …………… 274
15.3.7 String.split(Regexp) …………… 274
15.3.8 String.sub(Regexp, Str) ………. 275
15.3.9 String.gsub(Regexp, String) … 276
15.4 常用操作示例 … 276
15.4.2 提取 …. 277
15.4.3 替换 …. 277
15.4.4 切分 …. 277
15.5 Ruby 1.9的新变化 ………………………… 278
第16章 Objective-C ..280
16.1 预备知识 ……….. 280
16.2 正则功能详解 … 282
16.2.1 列表 …. 282
16.2.2 字符组 283
16.2.3 Unicode属性 ……………………. 284
16.2.4 字符组简记法…………………… 284
16.2.5 单词边界 …………………………. 285
16.2.6 行起始/结束位置 ……………… 286
16.2.7 环视 …. 287
16.2.8 匹配模式 …………………………. 287
16.2.9 纯文本模式 ……………………… 288
16.2.10 捕获分组的引用 ……………… 289
16.2.11 命名分组 ………………………… 290
16.3 正则API简介 .. 291
16.3.1 predicateWithFormat ………….. 291
16.3.2 rangeOfString ……………………. 292
16.3.3 regularExpressionWithPattern 292
16.3.4 initWithPattern ………………….. 292
16.3.5 pattern . 293
16.3.6 numberOfCaptureGroups ……. 293
16.3.7 numberOfMatchesInString ….. 293
16.3.8 stringByReplacingMatchesInString …………………….. 294
16.3.9 replacingMatchesInString …… 294
16.3.10 escapedPatternForString …… 294
16.3.11 escapedTemplateForString … 295
16.4 常用操作示例 … 295
16.4.1 验证 …. 295
16.4.2 提取 …. 295
16.4.4 切分 …. 298
第17章 Golang………..299
17.1 预备知识 ……….. 299
17.2 正则功能详解 … 301
17.2.1 列表 …. 301
17.2.2 字符组 301
17.2.3 Unicode属性 ……………………. 302
17.2.4 字符组简记法…………………… 303
17.2.5 单词边界 …………………………. 303
17.2.6 行起始/结束位置 ……………… 303
17.2.7 环视 …. 304
17.2.8 匹配模式 …………………………. 304
17.2.9 纯文本模式 ……………………… 305
17.2.10 捕获分组的引用 ……………… 305
17.2.11 命名分组 ………………………… 306
17.3 正则API简介 .. 307
17.3.1 Compile和MustCompile …… 307
17.3.2 MatchString ……………………… 308
17.3.3 FindString ………………………… 308
17.3.4 FindAllString ……………………. 309
17.3.5 FindStringIndex ………………… 309
17.3.6 FindAllStringIndex ……………. 309
17.3.7 FindStringSubmatch ………….. 309
17.3.8 FindAllStringSubmatch ……… 310
17.3.9 SubexpNames …………………… 310
17.3.10 Split … 311
17.3.11 ReplaceAllString ……………… 311
17.3.12 ReplaceAllLiteralString ……. 312
17.4 常用操作示例 … 312
17.4.1 验证 …. 312
17.4.2 提取 …. 312
17.4.3 替换 …. 313
17.4.4 切分 …. 313
18.1 POSIX …………… 314
18.1.1 POSIX规范 ……………………… 314
18.1.2 POSIX字符组 ………………….. 316
18.2 vi ………………….. 317
18.2.1 字符组及简记法 ……………….. 317
18.2.2 量词 …. 318
18.2.3 多选结构和捕获分组 ………… 319
18.2.4 环视 …. 319
18.2.5 锚点和单词边界 ……………….. 319
18.2.6 替换操作的特殊字符 ………… 320
18.2.7 replacement中的特殊变量 … 322
18.2.8 补充 …. 322
18.3 grep ………………. 323
18.3.1 基本用法 …………………………. 323
18.3.2 字符组 324
18.3.3 锚点和单词边界 ……………….. 324
18.3.4 量词 …. 324
18.3.5 多选结构和捕获分组 ………… 325
18.3.6 options . 325
18.3.7 egrep和fgrep …………………… 326
18.3.8 补充 …. 327
18.4 awk ……………….. 327
18.4.1 基本用法 …………………………. 327
18.4.2 字符组及简记法 ……………….. 328
18.4.3 锚点和单词边界 ……………….. 329
18.4.4 量词 …. 329
18.4.5 多选结构 …………………………. 330
18.4.6 补充 …. 330
18.5 sed ………………… 330
18.5.1 基本用法 …………………………. 330
18.5.2 字符组及简记法 ……………….. 331
18.5.3 锚点和单词边界 ……………….. 331
18.5.4 量词 …. 332
18.5.5 多选结构和捕获分组 ………… 332
18.5.7 补充 …. 333
18.6 总结………………. 334
附录A 常用语言中正则特性一览 ………………..337
附录B 常用的正则表达式 ………………………….340
附录C 常用的正则表达式工具及资源 ………….356
正则表达式术语中英文对照表 ………………………363
提到正则表达式,许多人很有点不屑一顾:这东西,不登大雅之堂,再说也不是总要用到,何必专门花时间学习?
没错,正则表达式并不“总要用到”,但如果到了需要的场合不会用,往往面临“一分钱难倒英雄汉”的困境。经常需要处理文本的程序员自然知道正则表达式的价值,其他的程序员如果不会正则表达式,即便开发的领域与文本处理没什么关系,也难以躲过“躺着中枪”的命运—前几天我遇到一个问题,将一行长长的地址拆分成多行,负责这部分的程序员的日常工作只是制作PDF而已,拆分地址是很“边缘”的功能,但不会正则表达式就无法准确折行(一般需要在标点符号出现的地方折行,而不能只在空白字符处折行,但是不同语言中的标点符号各有不同),结果一筹莫展;相反,如果了解正则表达式,就可以很容易地处理各种语言中的标点字符。
按照我的开发经验,专门花点时间学习一下正则表达式,确实很有必要。目前可以见到的关于正则表达式的书籍和资料有不少,但又各有不足。
在互联网上,流传着一些编程语言的正则文档和《30分钟教会你正则表达式》之类的帖子。这类资料的好处是简单直接,如果有现成的例子,而且适用于自己的语言,则可以直接抄来用。然而,其坏处也是简单直接,因为缺乏背后原理的讲解,如果找不到现成的例子,或者找不到能在自己所使用语言中行得通的例子(要知道,一种语言下的正则表达式往往并不能直接套用到另一种语言中),则束手无策。
在正式的出版领域,已经有《精通正则表达式》、《正则表达式必知必会》之类的书籍出版,尤其是前者,堪称关于正则表达式的经典著作,如果想认真学习正则表达式,这类书籍是必须阅读的。但这类书籍的弱点也很明显,即都是由英文版本翻译而来的,更多侧重英文文本的处理,身为中文世界的开发人员,我们经常需要处理中文文本—英文之外的字符。其实对于非英文字符的处理,正则表达式已经提供了足够丰富的功能,可惜资料相当匮乏。
为解决这些问题,我花了很多时间研习各种资料,然后经常给人讲解正则表达式的相关知识。我发现,很多人并不是不努力学,实在是合适的资料太少了。所以,我斗胆写作这本书。
相对于正则文档和速成教学帖子,本书深入讲解了匹配背后的原理,而且往往会举一反三,告诉读者,这里为何这样写,如果改成其他形式,会造成什么结构差异;同时集中讲解和比较了多种语言中正则表达式用法的异同,方便读者把现成的正则表达式“移植”到自己的工作环境中。
相对于《精通正则表达式》等“正式”的书籍,本书辟出专门的章节讲解语言和编码,告诉读者如何设定编码,如何正确处理中文字符等。另外,本书还涵盖了.NET、Java、JavaScript、PHP、Python、Ruby、Objective-C、Golang等常用语言,为每种语言专门撰写相关内容,不但详细介绍了语言中正则表达式的用法,更辨析了版本之间的细微差异,既可以作为专门学习的教材,也可以成为有用的参考手册。
本书结构
本书分为三部分。
第一部分主要讲解正则表达式的基础知识,覆盖常见正则表达式中的各种功能和结构。看完前3章,就可以基本弄明白现在流行的各种正则表达式;如果你之前有一些经验,会觉得阅读起来并不困难。但是我也希望读者不要忽略其他的内容,断言和匹配模式现在已经是正则表达式的“标准配置”了,而且确实可以派上大用场,所以第4章和第5章的内容,即便不是很熟悉,阅读起来可能有一些麻烦,但也不应该忽略。最后的第6章,则厘清了正则表达式在使用中的若干疑惑,了解它们,你就可以相对自如地穿行于正则表达式的世界了。
第二部分主要讲解关于正则表达式的深层次知识,这一部分用3章的内容,详细探讨了编码问题、匹配原理、解题思路。这部分内容更抽象,需要多花一点时间来阅读和理解,但是它们确实可以帮你在正则表达式的世界里登堂入室,脱离“术”的层面,掌握万变不离其宗的“道”。
第三部分的作用是接地气,将之前介绍的各种知识落实到常用语言.NET、Java、JavaScript、PHP、Python、Ruby、Objective-C、Golang中来。每一章的开头有正则功能列表,其中的功能对应着前面部分的讲解,这些功能的具体应用实例以及不同版本之间的差异,则在章节中详细讲解,每一章的最后还给出了常见任务的示例代码,方便日后查询。第18章简要介绍了正则表达式在Linux下常用工具vi、grep、awk、sed中的使用,并通过一个实际的例子将这几种工具串起来,对比说明了它们适合解决的问题。
在本书的最后提供了用作参考的3个附录。
附录A是正则表达式的常用功能在不同语言中的比对,希望能给需要在多种语言中使用正则表达式或者移植正则表达式的读者提供一份有用的参考;附录B给出了若干常见的正则表达式,比如匹配邮政编码、身份证号、手机号、QQ号、电子邮件地址等,希望能成为常见问题的“速查手册”;附录C列出了常用正则表达式的工具和资源,方便大家调试自己的正则表达式,以及继续深入学习。
本书的读者对象
本书适合以下几类读者:
经常需要进行文本处理(比如日志分析或网络运维)的技术人员。这些读者或许已经熟悉了正则表达式的基本用法,但面对日益复杂化和海量的数据,阅读本书可以帮助大家更准确、更高效地处理文本,提升自己工作的价值。
熟悉常用开发语言的程序员。虽然这些读者不需要专职进行文本处理,但源代码和许多数据其实也是文本,如果不会正则表达式,在偶然遇到处理源代码或文本数据的任务时,往往会产生无力感。本书的第三部分可以帮你快速找到有关的例子,并落实在自己的编程语言中。当然前两部分也非常有必要,因为它们可以帮你夯实基础。
对正则表达式已经有一定了解的读者。这些读者虽然能用正则表达式解决常见的问题,但未必了解正则表达式的编码问题、匹配原理、解题思路,仔细阅读本书的第二部分,可以深入完善对正则表达式的理解;而第三部分详细比较了可以使用正则表达式的各种语言,以及同一种语言中各种版本的差异。所有这一切,应该可以让你对正则表达式的掌握更上一层楼。
致谢
一本书的完成,离不开众多人的帮忙。
首先要感谢的是李笑来老师、周筠老师以及徐定翔和卢鸫翔两位编辑。在我翻译完《精通正则表达式》之后,李笑来老师三番五次地鼓励我写一本关于正则表达式的书,并且打消了我的很多顾虑;周筠老师、徐定翔和卢鸫翔两位编辑在我写作的最初阶段做了大量细致耐心的工作。可以说,没有他们,我就不会有写作这本书的念头,也不会有坚持完成的动力。
然后要感谢的是电子工业出版社的杨福平副总编、张月萍编辑、张春雨编辑和刘舫编辑,没有他们的关照和辛勤工作,这本书的出版定然会遇到更多的困难。
感谢我的朋友霍炬和韩磊,虽然我之前阅读过《精通正则表达式》,但与翻译和写作结缘,他们给了我莫大的帮助,于是今天才有了《正则指引》这本书。尤其值得一提的是,霍炬的夫人西乔,精心手绘了这本书的封面,我在这里要对她表示诚挚的谢意。
感谢我曾工作过的盛大创新院以及创新院的各位同事(李骏、郝培强、庄表伟、丁宇、许式伟、莫华枫、李道兵、赵劼、樊一鹏、张一宁等),创新院给了大家宽松自由的工作环境,与各位同事的讨论加深了我对正则表达式的理解,也为我提供了许多例子。
感谢张东亮、陆亦斌、孙勇、叶劲峰等各位朋友,愿意拨冗阅读本书的草稿,并提出了大量专业的意见。
感谢何源、陈钢、贺钧、陈驰等读者,试读本书之后提出了大量的宝贵意见,在最后关头打消了我心中的许多忐忑。
在更早之前,我的父母从小就鼓励我研究和了解各种科学原理(“玩也要动脑筋”),我之所以有兴趣探究正则表达式背后的世界,而不满足于“够用/凑合”,都是受益于这种思维行为习惯。在中小学阶段,我的语文老师罗碧玉、易玺铭培养了我对于文字的兴趣,在大学阶段,东北师范大学文学院的王确老师给了我这个理科生非常多的帮助和指引。对各位师长,在此一并表示感谢,能遇到你们是我的幸运。
最后还需要感谢许多为这本书做出过贡献的人,你们的名字我可能暂时无法记起,或者无法一一罗列,但我会在心中保持对你们的感谢。
我相信只有掌握并熟练运用它才有可能成为一名高效的工程师。期待每个人手边都有一本正则表达式的参考书,当然,希望就是你现在看到的这本。
就在写这句话的几分钟前,我又从这本书中学到了一个有用的技巧。
——冯大辉
配合恰当的案例,大量的反问,使读者自问、思考,扣人心扉,比较有代入感,加上配图,很容易让读者全面认识正则表达式。在原理讲解的章节,对比两种理论模型的区别,顺其自然地引入NFA引擎的关键要素一回朔,使读者从匹配原理上了解回溯,从而写出高效、严谨的正则表达式。
——陈驰
本书由浅入深地讲述了正则表达式,在正则表达式的应用和调优方面有非常详细的介绍,特别是在正则表达式处理中文方面有独到的阐述,对于需要经常处理中文的国内技术人员来说,本书无疑是非常值得拥有的一-本手册。
——贺钧
正则表达式是程序员的必备知识。如果您还没有使用过这个强大的工具,或者学习正则表达式总不得要领,建议读读本书。
——何源
这是一本通俗版的《精通正则表达式》。高手很难挑出毛病,一般程序员会受益匪浅,普通用户一步步读下去也能登堂入室。
——张东亮
余晟在之前翻译业内名著的基础上,结合中文环境和自己的丰富经验,再接再厉推出自己的作品,实在是我等码农的一大幸事。
——陈钢
评论
还没有评论。