java 通过正则表达式 获取纯文本信息

在java中,jeditorpane中,可以使用html格式,从而保证文本和图片的写入,为了对html中的文字部分设置样式,需要将文字部门全部提取出来,,在网上查出来的这段代码能删除html中的标签.

public static String Html2Text(String inputString){
     String htmlStr = inputString; //含html标签的字符串
     String textStr ="";
     java.util.regex.Pattern p_script;
     java.util.regex.Matcher m_script;
     java.util.regex.Pattern p_style;
     java.util.regex.Matcher m_style;
     java.util.regex.Pattern p_html;
     java.util.regex.Matcher m_html;

    try{
          String regEx_script = "<[\\s]*?script[^>]*?>[\\s\\S]*?<[\\s]*?\\/[\\s]*?script[\\s]*?>"; //定义script的正则表达式{或]*?>[\\s\\S]*?<\\/script> }
          String regEx_style = "<[\\s]*?style[^>]*?>[\\s\\S]*?<[\\s]*?\\/[\\s]*?style[\\s]*?>"; //定义style的正则表达式{或]*?>[\\s\\S]*?<\\/style> }
          String regEx_html = "<[^>]+>"; //定义HTML标签的正则表达式

          p_script = Pattern.compile(regEx_script,Pattern.CASE_INSENSITIVE);
          m_script = p_script.matcher(htmlStr);
          htmlStr = m_script.replaceAll(""); //过滤script标签

          p_style = Pattern.compile(regEx_style,Pattern.CASE_INSENSITIVE);
          m_style = p_style.matcher(htmlStr);
          htmlStr = m_style.replaceAll(""); //过滤style标签

          p_html = Pattern.compile(regEx_html,Pattern.CASE_INSENSITIVE);
          m_html = p_html.matcher(htmlStr);
          htmlStr = m_html.replaceAll(""); //过滤html标签

          textStr = htmlStr;
     }catch(Exception e){
         e.printStackTrace();
     }
     return textStr;//返回文本字符串
}  

 

 得到文字信息后,再通过string的fomat方法,就可以对文字进行样式的包装

     String.format("%s", editor)

 

你可能感兴趣的:(java,html,Java,正则表达式,HTML,String)