除了正则 我们还可以用什么方法将文本按行分开读取

前端之家收集整理的这篇文章主要介绍了除了正则 我们还可以用什么方法将文本按行分开读取前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

项目中,最近遇到一个需求,需求内容是 这样的:

1》在编辑文本框中输入内容,也可以从别处copy内容,然后在paste到文本框中

2》内容格式为手机号码,如下图:


3》最终需要将手机号码和单号分别匹配出来,显示到列表中,如下图:


我原本希望能找到一个正则正好将文本框中的内容按行分别获取到,但原谅我,我并没有找到一个很好的正则,不过找了如下一个正则来实现后,却是直接将文本按行打印了出来。如果看客们谁有更好的正则希望能带带我,哈哈。

public static void zhengZe(String s){
		Pattern pattern = Pattern.compile(".*?",Pattern.CASE_INSENSITIVE | Pattern.DOTALL);
		Matcher matcher = pattern.matcher(s);
		System.out.println(matcher.replaceAll(""));
	}
我传入的文本是
String s = "15202131503,222131332132113\n222223215456465 15202131503\r15202131500'adfadadsffa\r\nasdfsadfsadf\n\rasdfasdfadf";
结果打印出来却是:
15202131503,222131332132113
222223215456465 15202131503
15202131500'adfadadsffa
asdfsadfsadf


asdfasdfadf


虽然这与我要的结果很接近了,但问题出在,并不能使用while循环来分别获取然后打印,这个只能一次性打印。所以这并不是我要的结果。

于是我又在网上找,找了很久,发现好像可以用流来完成我的操作。下面是我实现成功的方法

public static void zhengZe(String s) throws IOException{
		BufferedReader br = new BufferedReader(new InputStreamReader(new ByteArrayInputStream(s.getBytes(Charset.forName("utf8"))),Charset.forName("utf8")));    
        String line;    
        StringBuffer strbuf=new StringBuffer();  
        while ( (line = br.readLine()) != null ) {    
            if(!line.trim().equals("")){  
                line="<br>"+line;//每行可以做加工  
                strbuf.append(line+"\r\n");  
            }                         
        }   
        System.out.println(strbuf.toString());  
	}
这样,通过while循环打印出来每行内容才是我要的方法。我就可以再单独对每行内容进行正则匹配,来获取手机号码和单号了。

看下打印结果:

<br>15202131503,222131332132113
<br>222223215456465 15202131503
<br>15202131500'adfadadsffa
<br>asdfsadfsadf
<br>asdfasdfadf

完美了,再通过正则将里面的符号空格去掉,匹配到两组数据,整个过程就完成了。

如果谁有更好的方法可以给我留个言,我一定虚心学习!

猜你在找的正则表达式相关文章