国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Java > 正文

java正則匹配HTML中a標簽里的中文字符示例

2019-11-26 13:17:49
字體:
來源:轉載
供稿:網友

本文實例講述了java正則匹配HTML中a標簽里的中文字符。分享給大家供大家參考,具體如下:

今天群里一位朋友問到了一個正則表達式的問題,有如下內容:

<a href='www.baidu.comds=id32434#comment'rewr>特432</a>453543<a guhll,,l>a1特123你好123嗎?</a><a href=id=32434#comment'ewrer>特2</a><a>標簽中的文字</a>

現在要匹配出內容包含中文但標簽的屬性中不包含comment的<a>標簽中的漢字。

解決思路如下:

1、首先匹配出不包括comment的<a>標簽;

2、在匹配結果中進行二次匹配出中文;

代碼如下:

package com.mmq.regex;import java.util.regex.Matcher;import java.util.regex.Pattern;/** * @use 匹配HTML的<a>標簽中的中文字符 * @ProjectName stuff * @Author mumaoqiang * @FullName com.mmq.regex.MatchChineseCharacters.java * @JDK 1.6.0 * @Version 1.0 */public class MatchChineseCharacters {  /**   * 根據輸入的內容,匹配出包含中文但不包含comment的<a>標簽中的中文字符   * @param source 要匹配的內容   * @return <a>標簽中的中文字符   */  public static String matchChineseCharacters(String source) {    //匹配出包含中文但不包含comment的<a>標簽    String reg = "<a((?!comment).)*?>([^<>]*?[//u4e00-//u9fa5]+[^<>]*?)+(?=</a>)";    Pattern pattern = Pattern.compile(reg);    Matcher matcher = pattern.matcher(source);    StringBuilder character = new StringBuilder();    while(matcher.find()){      String result = matcher.group();      System.out.println(result);      //對結果進行二次正則,匹配出中文字符      String reg1 = "[//u4e00-//u9fa5]+";      Pattern p1 = Pattern.compile(reg1);      Matcher m1 = p1.matcher(result);      while(m1.find()){        character.append(m1.group());      }      //System.out.println(character.toString());    }    return character.toString();  }  public static void main(String[] args) {    String result = matchChineseCharacters("<a href='www.baidu.comds=id32434#comment'rewr>特432</a>453543<a guhll,,l>a1特123你好123嗎?</a><a href=id=32434#comment'ewrer>特2</a><a>標簽中的文字</a>");    System.out.println(result);  }}

輸出結果如下:

<a guhll,,l>a1特123你好123嗎?<a>標簽中的文字特你好嗎標簽中的文字

這里做一下解釋:

String reg = "<a((?!comment).)*?>([^<>]*?[//u4e00-//u9fa5]+[^<>]*?)+(?=</a>)";

這個匹配內容包含中文但標簽的屬性中不包含comment的<a>標簽的正則中,不能使用向后查找?<=,因為向后查找只能是固定長度的內容,這里<a>標簽中屬性不確定,所以不能使用;[//u4e00-//u9fa5]+匹配中文字符串;而(?=</a>)使用向前查找?=,在結果中不會包含結束標簽</a>。

這個問題就這樣得到解決了。如果說要匹配指定標簽中的指定內容,那么也是很容易改進的了。若有更好的正則,還請留言相互學習。

PS:這里再為大家提供2款非常方便的正則表達式工具供大家參考使用:

JavaScript正則表達式在線測試工具:
http://tools.VeVB.COm/regex/javascript

正則表達式在線生成工具:
http://tools.VeVB.COm/regex/create_reg

希望本文所述對大家java程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 肥西县| 扎囊县| 中山市| 读书| 濮阳市| 洪湖市| 夏津县| 高安市| 常州市| 任丘市| 弥勒县| 兰考县| 社会| 郴州市| 阜平县| 隆安县| 道真| 旌德县| 九江市| 西峡县| 大理市| 新竹市| 洮南市| 二连浩特市| 阳泉市| 贵德县| 屏边| 丹棱县| 民权县| 皮山县| 渝北区| 含山县| 搜索| 邹城市| 调兵山市| 曲水县| 岑巩县| 乡城县| 南充市| 银川市| 公主岭市|