欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

正则表达式中环视的简单应用示例【基于java】

程序员文章站 2022-06-23 11:32:10
本文实例讲述了正则表达式中环视的简单应用。分享给大家供大家参考,具体如下: 由于开发工作需要对文本中内容进行过滤,删除或替换掉一些无用的或不符合要求的信息。于是发现一个问...

本文实例讲述了正则表达式中环视的简单应用。分享给大家供大家参考,具体如下:

由于开发工作需要对文本中内容进行过滤,删除或替换掉一些无用的或不符合要求的信息。于是发现一个问题,某一类工程性文本中,用到很多英文写法相同、但含义不同的单位,需要将其分别转为真实含义对应的汉字。比如:"粘度为17s,移动距离为350厘米,要求混凝土必须内实外光。振捣时间为30s。",很明显第一个s是粘度的单位,第二s是时间单位,现在需要将文本中所有表示时间的s替换为“秒”,在朋友指引下,发现通过正则表达式中的环视可以方便实现这功能。

正则表达式中的环视,大家公认的基本原理是依据位置信息来进行匹配。我认为,还可以把它理解为依据目标字符的上下文进行匹配。

具体的java代码如下

package ccnu;
import java.util.regex.matcher;
import java.util.regex.pattern;
import java.util.regex.patternsyntaxexception;
public class regex {
  /**
   * @param args
   */
  public static void main(string[] args) {
    // todo auto-generated method stub
    string temphtmlstring="粘度为17s,移动距离为350厘米,要求混凝土必须内实外光。振捣时间为30s。";
    pattern p_html;
    matcher m_html;
    string regex = "([^粘度][u4e00-u9fa5]{1,10}(?<=[0-9]))s([^a-z]$)";
    p_html = pattern.compile(regex);
    m_html = p_html.matcher(temphtmlstring);
    string resultstring="";
    try {
      resultstring = m_html.replaceall("$1秒");
    } catch (patternsyntaxexception ex) {
      // syntax error in the regular expression
    } catch (illegalargumentexception ex) {
      // syntax error in the replacement text (unescaped $ signs?)
    } catch (indexoutofboundsexception ex) {
      // non-existent backreference used the replacement text
    }
    system.out.println(resultstring);
  }
}

结果:粘度为17s,移动距离为350厘米,要求混凝土必须内实外光。振捣时间为30秒。

ps:这里再为大家提供2款非常方便的正则表达式工具供大家参考使用:

javascript正则表达式在线测试工具:

正则表达式在线生成工具:

希望本文所述对大家正则表达式学习有所帮助。