• 正则表达式替换文字 表达式If you’re just starting out with regular expressions (regex), the syntax can seem a bit puzzling at first (I would recommend Jason Pasnikowski’s article as a good starting ...

正则表达式替换文字 表达式
If you’re just starting out with regular expressions (regex), the syntax can seem a bit puzzling at first (I would recommend Jason Pasnikowski’s article as a good starting point). One of the things that make it difficult to grasp regex in the beginning is the small number of times you have a chance to use them in your code, which in turn limits the amount of practice you have using them. Professionals in any capacity, be it sports, entertainment, or development always practice – some practice more than others.
如果您只是从正则表达式(regex)开始，那么语法起初似乎有些令人费解(我建议Jason Pasnikowski的文章作为一个很好的起点)。 一开始让正则表达式难以理解的一件事是您有机会在代码中使用正则表达式的次数很少，这反过来又限制了您使用正则表达式的次数。 无论是运动，娱乐还是发展，任何能力的专业人员都经常练习-有些练习比其他练习更多。
So how can you practice using regex if you are limited to just using them in your code? The answer is to use a utility, of which there are many, that uses regex for performing search and replace. I’m sure everyone is familiar with the standard “find x and replace it with y” type of search and replace. Most IDEs and text editors have built in regex engines to handle search and replace. In this article I’d like to walk through a series of exercises to help you practice using regex.
因此，如果您仅限于在代码中使用正则表达式，该如何练习使用正则表达式？ 答案是使用一个实用程序，其中有很多使用regex执行搜索和替换。 我确信每个人都熟悉标准的“查找x并将其替换为y ”类型的搜索和替换。 大多数IDE和文本编辑器都内置了正则表达式引擎来处理搜索和替换。 在本文中，我想通过一系列练习来帮助您练习使用正则表达式。
I’ll be using NetBeans for this article. Some editors might have slightly different regex behavior that what you see here, so if you’re using something other than NetBeans and it doesn’t work quite as you’d expect, be sure to read the documentation for your specific editor.
我将在本文中使用NetBeans。 一些编辑器的正则表达式行为可能与您在此处看到的略有不同，因此，如果您使用的不是NetBeans，则不能正常使用，请确保阅读特定编辑器的文档。
词边界 (Word Boundaries)
Let’s use the following code to start with for our examples; I’ve crafted it specifically to illustrate particular caveats of search and replace as your progress.
让我们使用以下代码作为示例。 我特意制作了它，以说明搜索的特定注意事项并随您的进度进行替换。
<div id="navigation">
<a href="indivisible.php" title="Indivisible by Zero">Indivisible Numbers</a>&nbsp;&nbsp;|&nbsp;&nbsp;
</div>
This navigation code should ideally be an unordered list, not free anchors inside div tags. You can’t just replace the word “div” with “ul” however because divebomb would become ulebomb, endives would become enules, etc. You also can’t use “<div” because it would miss the closing div tag. You can manually replace the div tags with ul tags, or you can use the special sequence b which denotes a word boundary.
理想情况下，此导航代码应该是无序列表，而不是div标签中的自由锚。 但是，您不能仅用“ ul”替换“ div”一词，因为Divedbomb会变成ulebomb，菊苣会变成enule，等等。您也不能使用“ <div”，因为它会错过结束div标签。 您可以使用ul标签手动替换div标签，也可以使用表示单词边界的特殊序列b 。
In the Search field, type: bdivbIn the Replace field, type: ul
在“搜索”字段中，键入： bdivb在“替换”字段中，键入： ul
This only replaces the text “div” that was delimited by word boundaries. Word boundaries allow you to perform whole word only searches, so the word “div” in <div id=”navigation”> and </div> both get matched while the substrings in the anchors are left alone.
这仅替换了由单词边界分隔的文本“ div”。 单词边界允许您执行全单词搜索，因此<div id =“ navigation”>和</ div>中的单词“ div”都将匹配，而锚点中的子字符串则保持不变。
Later you’ll also see w, which is used to match non-whitespace “word” characters.
稍后您还将看到w ，它用于匹配非空白的“单词”字符。
分组和反向引用 (Groupings and Back References)
Continuing with the modified code from the first example, let’s continue refactoring the list. Right now your code should look like this:
继续第一个示例中的修改后的代码，让我们继续重构列表。 现在，您的代码应如下所示：
<ul id="navigation">
<a href="indivisible.php" title="Indivisible by Zero">Indivisible Numbers</a>&nbsp;&nbsp;|&nbsp;&nbsp;
</ul>
You can easily do a standard search and replace on the anchor tags without any of the issues that prevented you from doing so with div, but where is the fun in that? In the spirit of practice, let’s use regex to wrap the anchors in li tags.
您可以轻松地进行标准搜索并替换锚标记，而不会遇到任何妨碍div的问题，但是这样做的乐趣何在？ 本着实践的精神，让我们使用正则表达式将锚点包装在li标签中。
To select the anchors, type the following in the Search field: (<a.*>)In the Replace field, type: <li>$1</li> 若要选择锚点，请在“搜索”字段中键入以下内容： (<a.*>)在“替换”字段中，键入： <li>$1</li>
Ignoring the parentheses in the search pattern for now, let’s break up the pattern and discuss each piece of it. The first piece is <a, which tells the regex engine to match a less-than symbol followed by the letter a. The next part of this piece is .*>, which tells the engine to match any character zero or more times followed by a greater-than symbol. This piece matches the anchor tags in the block of code above.
现在暂时忽略搜索模式中的括号，让我们分解一下模式并讨论它的每一部分。 第一个是<a，它告诉正则表达式引擎匹配一个小于号，后跟字母a 。 这部分的下一部分是。*>，它告诉引擎将任何字符匹配零次或多次，后跟一个大于号。 这部分与上面代码块中的anchor标签匹配。
The parentheses in the search pattern perform a special function; they group the individual matches which you can access later. By adding the parentheses, you are telling the regex engine to store the matching result because you’ll need them later. You can access these groups by number.
搜索模式中的括号执行特殊功能； 他们将各个匹配项分组，您以后可以访问。 通过添加括号，您是在告诉正则表达式引擎存储匹配结果，因为稍后将需要它们。 您可以按编号访问这些组。
The replace pattern tells the engine to replace the search pattern with an opening li tag, followed by the contents in the first grouping, and a closing li tag. In this example there is only one group (because there is only one set of parenthesis), so the $1 in the middle of the li tags indicates this is the group you want to use. (Some editors may use 1 instead of $1. If $1 does work, then undo your replacement and try the other variant.) 替换模式告诉引擎用开头的li标签，后跟第一个分组中的内容和结尾的li标签替换搜索模式。 在此示例中，只有一个组(因为只有一组括号)，因此li标记中间的$1表示这是您要使用的组。 (某些编辑器可能会使用1而不是$1如果$1起作用，请撤消替换，然后尝试其他变体。)
You can have multiple groups, and groups can be nested which you’ll see in just a moment. You’re going to modify the patterns you just used to add the li tags in order to create a more robust navigation. Undo the replacements you’ve just made. Usually something like Ctrl+Z works just fine, but if it doesn’t here’s the search and replace patterns to revert the code:
您可以有多个组，并且可以嵌套组，稍后您将看到它们。 您将修改刚刚用于添加li标签的模式，以创建更强大的导航。 撤消刚刚完成的替换。 通常，像Ctrl + Z类的东西就可以正常工作，但是如果不行，这里是搜索和替换模式以还原代码：
In the Search field, type: <li>(<a.*>)</li>In the Replace field, type: $1 在“搜索”字段中，键入： <li>(<a.*>)</li>在“替换”字段中，键入： $1
多个分组 (Multiple Groupings)
Alright, now let’s wrap the anchor tags in li tags complete with class and id attributes for use with CSS. To accomplish this, you’ll use the following:
好了，现在让我们将锚标签包装在带有class和id属性的li标签中，以供CSS使用。 为此，您将使用以下内容：
Search: (<a.*>(w+).*</a>)Replace: <li class="navEntry" id="$2">$1</li>
搜索： (<a.*>(w+).*</a>)替换： <li class="navEntry" id="$2">$1</li>
As in the second example’s search pattern, <a.*> matches the anchor tags. You’re asking the regex engine to find a string that begins with a greater-than symbol, followed by the letter a, followed by series of zero or more characters that ends with a less-than symbol. With w+ you are also asking the engine to look for a sequence of characters that doesn’t contain any whitespace or symbol characters and has a length greater than zero. The parentheses around w+ indicate you want to store the match as a group. Next you added .* to the pattern to match any other characters that may appear before the closing of the anchor tag. The result is that $1 will have the matched anchor string, and $2 will have the first word of the link’s text.
与第二个示例的搜索模式一样，<a。*>匹配锚标记。 您要让正则表达式引擎查找以大于号开头的字符串，然后是字母a ，然后是一系列零个或多个以小于号结尾的字符。 使用w+您还要求引擎寻找不包含任何空格或符号字符且长度大于零的字符序列。 w+周围的括号表示您要将匹配存储为一个组。 接下来，您将。*添加到模式中，以匹配锚标记关闭之前可能出现的任何其他字符。 结果是$1将具有匹配的定位字符串，而$2将具有链接文本的第一个单词。
Breaking down the replacement, you begin with li, a class attribute and its value, followed by the id attribute. Instead of providing an id value however you have $2. This tells the regex engine you want to use the content stored in the second group from the search pattern, which in this case is the w+. Then you open the li tag, tell the regex engine you want to use the first grouping ($1 is the entire anchor tag), and finally close the li tag.
要分解替换项，请从li ， class属性及其值开始，然后是id属性。 除了提供id值之外，您还有$2 。 这告诉正则表达式引擎您要使用搜索模式中第二组中存储的内容，本例中为w+ 。 然后，您打开li标签，告诉正则表达式引擎您要使用第一个分组( $1是整个锚标签)，最后关闭li标签。
Be careful when you are determining which groups to replace. Consider the following hypothetical example (I’ve used group names instead of patterns to illustrate how grouping works):
确定要替换的组时请小心。 考虑下面的假设示例(我使用组名而不是模式来说明分组的工作方式)：
(group1(group2))(group3)

Using the above gives you the following results:
使用上面的方法可以为您提供以下结果：
$1 = group1group2$2 = group2
$3 = group3 $1 contains both group1 and group2 because parentheses enclose both of them. This is true even though group2 is a group by itself. And then of course group3 is a group to itself.
$1包含group1和group2，因为括号将它们都包围了。 即使group2本身是一个组，也是如此。 当然， group3本身就是一个组。 To finish cleaning things up, you can remove the non-breaking space entities and the pipe character from the end of the lines and replace them with an empty string (the pipe needs to be preceded by a backslash in the expression because it has special meaning to the engine). 要清理完所有内容，您可以从行尾删除不间断的空格实体和管道字符，然后将它们替换为空字符串(管道在表达式中必须以反斜杠开头，因为它具有特殊含义引擎)。 Search: &nbsp;&nbsp;|&nbsp;&nbsp;Leave the Replace field empty. 搜索： &nbsp;&nbsp;|&nbsp;&nbsp; 将“替换”字段留空。 You’re code should now look like this – a nice, neat, well-structured list you can use CSS with to style: 您的代码现在应该看起来像这样–一个漂亮，整洁，结构良好的列表，可以使用CSS进行样式设置： <ul id="navigation"> <li class="navEntry" id="Divebombs"><a href="divebomb.php" title="All About Divebombs">Divebombs</a></li> <li class="navEntry" id="Endives"><a href="endives.php" title="All About Endives">Endives</a></li> <li class="navEntry" id="Indivisible"><a href="indivisible.php" title="Indivisible by Zero">Indivisible Numbers</a></li> <li class="navEntry" id="Divison"><a href="division.php" title="All About Division">Divison</a></li> <li class="navEntry" id="Skydiving"><a href="skydiving.php" title="All About Skydiving">Skydiving</a></li> </ul> 摘要 (Summary) Thanks for taking some time to learn a little bit more about regular expressions and practicing with them using search and replace. I encourage anyone who is struggling to grasp the concepts to practice using search and replace in their editor because it’s convenient and generally provides immediate visual feedback. If necessary, you can copy and paste the content you’re working with into a blank file and experiment with it, running replacements and undoing them, until you get what you like. 感谢您抽出一些时间来学习有关正则表达式的更多信息，并使用搜索和替换对其进行练习。 我鼓励任何努力掌握概念的人在其编辑器中使用搜索和替换来实践，因为它很方便并且通常会立即提供视觉反馈。 如有必要，您可以将正在使用的内容复制并粘贴到空白文件中并进行实验，运行替换并撤消替换，直到获得所需的内容。 翻译自: https://www.sitepoint.com/practicing-regular-expressions/ 正则表达式替换文字 表达式  展开全文 • 主要介绍了SQL Server中利用正则表达式替换字符串的方法,非常不错，具有参考借鉴价值，需要的朋友可以参考下 • Idea内使用正则表达式替换功能简记 前言：工作上遇见过需要对某个实体类对象进行批量替换的操作，在对象的属性比较少的时候可以ctrl+c/v很快速地进行替换，但是一旦对象的属性多起来，这种纯粹的机械式劳动就会耗费...  Idea内使用正则表达式替换功能简记 前言：工作上遇见过需要对某个实体类对象进行批量替换的操作，在对象的属性比较少的时候可以ctrl+c/v很快速地进行替换，但是一旦对象的属性多起来，这种纯粹的机械式劳动就会耗费大量的时间。 本文记录一下自己在日常工作中采取的正则替换策略以及搜集到的正则表达式知识，以便更好地学习和理解正则表达式。 放上一个正则表达式入门教程：正则表达式30分钟入门教程 作者：deerchao 场景1： 现在有一个实体类，需要将属性值和属性名提取成json格式来编写api，成品格式为： { "pageId": "页面ID", "pageName": "页面名称" }  以下是实体类：  public class CmsPage { /** * 页面名称、别名、访问地址、类型（静态/动态）、页面模版、状态 */ //站点ID private String siteId; //页面ID private String pageId; //页面名称 private String pageName; //别名 private String pageAliase; //访问地址 private String pageWebPath; //参数 private String pageParameter; //物理路径 private String pagePhysicalPath; //类型（静态/动态） private String pageType; //页面模版 private String pageTemplate; //页面静态化内容 private String pageHtml; //状态 private String pageStatus; //创建时间 private Date pageCreateTime; //模版id private String templateId; //参数列表 private List<CmsPageParam> pageParams; //模版文件Id private String templateFileId; //静态文件Id private String htmlFileId; //数据Url private String dataUrl; }  首先将这些属性复制到一个临时的json文件里，并调出替换框 这里我使用的匹配规则是： \/\/(.*)\n(.*) (.*) (.*); 这条正则表达式的含义：正则表达式里面的符号都需要反斜杠来转义，所以\/就表示单条斜杠，(.*)匹配斜杠后面的字符串，\n匹配回车符。 \n匹配回车符会出现匹配不上的问题，可以打开文件→文件属性→行分隔符，选择LF或按照如下图进行设置。 句子中使用了4个(.*)，属性中文名和英文名分别为第一个和第4个，所以在替换公式中可以用$1和$4来代替，具体替换公式如下。 点击全部替换（replace All），然后加上花括号，就完成了。 嗯…… 看了会儿教程感觉自己对正则表达式的应用实在是太浅了，下面为正则表达式学习过程中的记录。 正则匹配中 ^$ 和 \b 的区别
^和$分别代表字符串的开始和结束，因此^\d$只能匹配包含一个数字的字符串。\b代表单词边界，其前后必须是不同类型的字符，可以组成单词的字符为一种类型，不可组成单词的字符(包括字符串的开始和结束）为另一种类型。 因此\b\d\b可以匹配%3%中的3,但不能匹配23中的任意一个数字。
5   // ^\d$可匹配； \b\d\b可匹配 %2@!22$2$// \b\d\b可匹配第一个和第四个2 264 //均不能匹配  展开全文 • 目标：在这些大写缩写（用([A-Z]+:)正则表达式选出）前加一个换行符, 实现每个缩写都独立在一行。 实现方法：使用 Sublime Text的替换功能。在 Replace With 一栏填入\n$1， 点击 Replace All按钮就可以了。$1表示...  目标：在这些大写缩写（用([A-Z]+:)正则表达式选出）前加一个换行符, 实现每个缩写都独立在一行。 实现方法：使用 Sublime Text的替换功能。在 Replace With 一栏填入\n$1， 点击 Replace All按钮就可以了。$1表示上面那个正则表达式第一个括号内的内容。效果如下。 替换 注释 //中文 //([\u4e00-\u9fa5，；、：]+) 转载地址：https://blog.csdn.net/u013704227/article/details/53669497 展开全文 • /*** 此方法描述的是：字符串的替换* @param string需要替换的字符串* @param oldString被替换的字符串* @param newString新字符串* @author 作者 E-mail: wangxiongdx@163.com* @version 创建时间：2009-9-13 下午...  /** * 此方法描述的是：字符串的替换 * @param string需要替换的字符串 * @param oldString被替换的字符串 * @param newString新字符串 * @author 作者 E-mail: wangxiongdx@163.com * @version 创建时间：2009-9-13 下午01:34:23 */ public static String replace(String string, String oldString, String newString) { if (string == null) { return null; } int i = 0;//初始位置，从0开始 //从指定位置开始查找oldString在string中的起始位置 if ((i = string.indexOf(oldString, i)) >= 0) { // Use char []'s, as they are more efficient to deal with. char[] string2 = string.toCharArray(); char[] newString2 = newString.toCharArray(); int oLength = oldString.length(); //StringBuilder 简易替换 比 StringBuffer 要快 StringBuilder buf = new StringBuilder(string2.length); //string2从起始位置到 i 的部分... 继续追加新串 newString2 buf.append(string2, 0, i).append(newString2); //string中旧字符串的结束位置 i += oLength; int j = i; // Replace all remaining instances of oldString with newString. //用新串替换所有出现的旧串 while ((i = string.indexOf(oldString, i)) > 0) { buf.append(string2, j, i - j).append(newString2); i += oLength; j = i; } //用新串替换后的string2中截获最后一次出现新串的结束位置到结尾 buf.append(string2, j, string2.length - j); return buf.toString(); } return string; } /** * 此方法描述的是：使用正则替换字符串tt中含有的html标签和js标签 * @param string传入字符串 * @author 作者 E-mail: wangxiongdx@163.com * @version 创建时间：2009-9-29 下午03:34:23 */ public static String stripHTMLTags(String tt){ //匹配所有带字母的标签(包括js标签) String tag = "?[a-zA-Z]*([\\s]*([A-Za-z]+[\\s]?=[\\s]?(\"|')?[\\w]+(\"|')?))*>"; //匹配js标签 String javascriptTag = " Pattern p = Pattern.compile(tag); //起始 int index = 0; //结束 int last; while((index = tt.indexOf("<",index)) != -1){ if((last = tt.indexOf(">",index)) != -1){ //目标字符串 String oldString = tt.substring(index, last+1); Matcher m = p.matcher(oldString); //首先判断是否为js标签 if(Pattern.compile(javascriptTag).matcher(oldString).matches()){ if((last = tt.indexOf("",last)) != -1){ tt = replace(tt, tt.substring(index, last+9), ""); } //再判断是否为html标签(html正则考虑去除js标签正则？？？后补) }else if(m.matches()){ tt = replace(tt, oldString, ""); } }else{ break; } } return tt; }  展开全文 • 源地址：...对于替换功能，一般的文本编辑器，都具有此功能，但是对于高级的正则表达式替换，则很多都不支持。而此处Notepad++支持此 • 当遇到一个文本处理问题时，如果你在第一时间想到了正则表达式，那么恭喜你，你的问题从一个变成了俩！“ 如果你曾参与过文本数据分析，正则表达式（Regex）对你来说一定不陌生。词库索引、关键词替换……正则... • 正则表达式替换 千次阅读 2019-04-06 16:22:01 在做项目时有时候会去大量替换图片、样式等等，如果一条条的去替换效率不高这个时候可以用正则去进行大批量的替换把符合你正则里面的条件的全部替换掉，如同下图先进行条件匹配 这里我们匹配到src中间的位置下面就... • EditPlus正则表达式替换字符串详解 发布时间：April 8, 2007 分类：Regular 《PHP 实现多服务器共享 SESSION 数据》 《利用javascript在页面上点击任一链接时触发事件》 网上搜集了些实例 正则表达式是一... • RegeX是一款正则表达式辅助程序，它通过高亮匹配及替换内容使整个流程可视化，帮助用户更好地理解和使用正则表达式这一强力工具。 RegeX定位为免费软件，任何人都可无限制的使用它。 它的前身叫做SearchRex，此前我... • 有几个字符串 str1="[id=1,name=张三,age=3]"; str2="id=编号"; str3="name=张三"; str4="age=年龄"; 想用正则替换成最终效果 str=[编号=1,姓名=张三，年龄=3]， 请教大神用正则该怎么替换 • idea 将 @RequiresPermissions("sys:ruletriggerlog:list") 替换为@PreAuthorize("hasAuthority('sys:ruletriggerlog:list')") @RequiresPermissions$$\"(.*?)\"$$ @PreAuthorize("hasAuthority('$1')") 全局...
• PHP基于正则表达式替换的模板引擎很久没有遇上PHP难题了，这次正则问题占了一点时间，还是老问题最大回溯、递归限制问题。学习透之后其实并不难修改调试有这类问题的正则。主要是以下几点。基于正则表达式替换的模板...
• ctrl+h调出替换面板，勾选下方正则表达式选项，再在查找目标里面输入要匹配的正则即可，如匹配每一行的开始^，每一行的结束$，如图所示。 • JS正则表达式完整版 万次阅读 多人点赞 2018-07-17 13:14:13 第一章 正则表达式字符匹配攻略 1 两种模糊匹配 2. 字符组 3. 量词 4. 多选分支 5. 案例分析 第1章 小结 第二章 正则表达式位置匹配攻略 1. 什么是位置呢？ 2. 如何匹配位置呢？ 3. 位置的特性 4. 相关... • 前段时间需要批量替换代码，就写了段正则表达式来处理。存着下次用。 整个项目中需要替换的代码： // the line below is added for pagination StringBuffer pathBuffer = new StringBuffer(); path... • C#（.NET）模板字符串占位符正则表达式替换（类EL表达式） 因为需要自己写一个日志记录工具，文件名可以在配置文件中配置，能够支持模板替换自定义文件名，所以在此将模板字符串占位符替换的源代码贴出，以备后忘。 ... • 在开发中，正则表达式通常被用来检索、替换那些符合某个规则的文本。 正则表达式的匹配规则 参照帮助文档，在Pattern类中有正则表达式的的规则定义，正则表达式中明确区分大小写字母。我们来学习语法... • java正则表达式用法示例 当我开始使用Java时，正则表达式对我来说是一场噩梦。 本教程旨在帮助您掌握Java正则表达式，并让我定期返回以刷新我的正则表达式学习。 什么是正则表达式正则表达式定义字符串的... • 正则表达式替换汉字和数字 千次阅读 2017-10-20 18:35:34 替换所有汉字 public static void main(String[] args) { String str = "温度调整到1000度1"; String reg = "[\u4e00-\u9fa5]"; Pattern pat = Pattern.compile(reg); Matcher mat=pat.... • 把AAAA替换为A-A-A-A- javascript alert('AAAA'.replace(/([A]{1})/g,&amp;amp;amp;amp;amp;amp;amp;amp;amp;amp;amp;amp;amp;amp;amp;amp;amp;amp;amp;amp;amp;amp;amp;amp;amp;amp;amp;quot;$1-&amp;...
• PHP中的正则表达式函数 ...PCRE库使用和Perl相同的语法规则实现了正则表达式的模式匹配，其使用以“preg_”为前缀命名的函数。另一套是由POSIX（Portable Operation System interface）扩展库提供的。POSIX扩展
• 需求是：将”冰\\雨三刘德\\\...正则表达式是我的老朋友了，喜欢上它大概是07年的时候处理一个发布系统标签读取的项目，最近也好长时间也没用了，有点生疏了。遇到字符串处理的问题，我第一想到的肯定是正则表达式，ec
• 或许会有更好的解决办法，我这里还是采用正则来解决，顺便复习下很久没用过的正则表达式。 有一个json字符串如下： {"code":0,"students":{"s001":{"sname":"张三","sage":"10"},"s002":{"sname":"李四","sage":...
• 比如，在列模式下编辑得到的内容往往含有很多不需要的空格，这个时候需要使用正则表达式替换。  这里使用的是ue中的unix正则表达式引擎，替换表达式是："(/s*)([a-z]+)/s*" 替换为："/2"。 解释： 上面...
• 撰写时间：2019.04.06 在各种数据转换中，数据不一定会转换成我们想要的数据格式，就比如我们下面的这些从控制台得到数据一样： 我们需要对得到的IsTIme和StTime两条数据进行分割处理让他们变成数组，然后再进行...
• sublime text 正则表达式替换

千次阅读 2014-10-14 17:54:55
忽然想起，可以使用正则表达式，bingo！！！ sublime text正常搜索替换是这种，纯文字的 我们需要用到正则表达式，所以点击最左边的“.*”按钮： 然后就可以匹配了。 但是又碰到个问题，如果可以匹配...

...