zoukankan      html  css  js  c++  java
  • JAVA中取子字符串的几种方式

    有这样一串字符串:String s = "共 100 页, 1 2 3 4...";

    假如我想把"100"给取出来,该如何做?

    方法一: 采用split的方式

    System.out.println(s.split(" ")[1]);或者System.out.println(s.split("\s")[1]);

    假如空" "有多个时,可以这样:
    System.out.println(s.split("\s+")[1]);

    注:split是支持正则的,s在正则中表示空格,+在正则中表示至少1个,即1个或多个,所以s+表示至少有一个空格

    方法二: 采用indexOf的方式

    int begin = s.indexOf(" ");
    int end = s.indexOf(" ", begin+1);
    System.out.println(s.substring(begin+1, end));

    方法三: 正则

    封装好的一个正则类:

    public class RegExp {
    
    	public boolean match(String reg, String str) {
    		return Pattern.matches(reg, str);
    	}
    
    	public List<String> find(String reg, String str) {
    		Matcher matcher = Pattern.compile(reg).matcher(str);
    		List<String> list = new ArrayList<String>();
    		while (matcher.find()) {
    			list.add(matcher.group());
    		}
    		return list;
    	}
    	
    	public String find(String reg, String str, int index) {
    		Matcher matcher = Pattern.compile(reg).matcher(str);
    		if (matcher.find()) {
    			return matcher.group(index);
    		}
    		return null;
    	}
    
    	public String findString(String reg, String str) {
    		String returnStr = null;
    		List<String> list = this.find(reg, str);
    		if (list.size() != 0)
    			returnStr = list.get(0);
    		return returnStr;
    	}
    
    }
    

     RegExp re = new RegExp();
     System.out.println(re.findString("\d+", s));

     System.out.println(re.findString("(?<=共).*?\d+", s).trim());

    注:正则中d表示数字,(?<=共)是一种预查模式

    方法四: 采用replaceFirst的方式

    System.out.println(s.replaceFirst(".*?(\d+).*", "$1"));

    replaceFirst也是支持正则的

    注: ?在正则中表示最小匹配模式,$1表示第一个()表示式里面的内容。

    以上四种方法中,其中有三种都与正则有关系,所以,要想玩转字符串的操作,具备一定的正则表示式的能力还是很有必要的!

  • 相关阅读:
    zabbix报警把特定的应用集发送给developer
    logstash 判断接口响应时间发送zabbix告警
    zabbix 对于logstash告警连续发邮件
    java使double保留两位小数的多方法
    Vagrant 和 docker
    golang binarySearch
    go channel实现
    5个jvm命令
    字符串匹配的Boyer-Moore算法
    Rabin-Karp 算法
  • 原文地址:https://www.cnblogs.com/zhangfei/p/5092220.html
Copyright © 2011-2022 走看看