文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

如何在 Java 中优雅地分割 String 字符串

2024-12-03 07:08

关注

[[393207]]

使用方法

split 方法的一种声明为,

  1. public String[] split(String regex) 

其中 regex 指的是正则表达式分隔符,我们平时使用单个字符作为分隔符,其实可以看作特殊的正则表达式,特殊之处在于这种表达式只匹配它自身,如 "-" 只匹配 "-", 示例如下:

  1. String string = "86-15003455666"
  2. String[] parts = string.split("-"); 
  3. String part1 = parts[0]; // 86 
  4. String part2 = parts[1]; // 15003455666 

split 方法的另一个声明为:

  1. public String[] split(String regex, int limit) 

regex 指的是 正则表达式分隔符,limit 指定的则是分割的份数,举个例子就明白了

  1. String string = "004-556-42"
  2. String[] parts = string.split("-", 2);   // 限定分割两份 
  3. String part1 = parts[0]; // 004 
  4. String part2 = parts[1]; // 556-42 

而在某些场景下,我们可能想要在结果中保留分隔符,这也是可以做到了设置分隔符与分割后左侧的结果相连,

  1. String string = "86-15003455666"
  2. String[] parts = string.split("(?<=-)"); 
  3. String part1 = parts[0]; // 86- 
  4. String part2 = parts[1]; // 15003455666 

设置分隔符与分割后右侧的结果相连,

  1. String string = "86-15003455666"
  2. String[] parts = string.split("(?=-)"); 
  3. String part1 = parts[0]; // 86 
  4. String part2 = parts[1]; // -15003455666 

机智的你可能已经发现了,其实分割方法的精妙之处,全在于正则表达式 regex 的设置,正则表达式还是要好好学习的!

妙用正则表达式

在实际的工作场景中,对于要分割的字符串,我们在分割之前,往往需要校验下它的格式,只有符合我们的要求,我们才对它进行拆分处理。而使用 Pattern 类加 Matcher 类,可以使字符串的格式识别和分割操作一气呵成:

  1. public class SplitExample { 
  2.     //\d代表数字,+代表出现一次或多次。所以(\\d+)-(\\d+)匹配用"-"相连的两个数字串 
  3.     // Pattern 对象是正则表达式的编译表示 
  4.     private static Pattern twopart = Pattern.compile("(\\d+)-(\\d+)"); 
  5.  
  6.     public static void checkString(String s) 
  7.     { 
  8.         // Matcher对象对输入字符串进行解释和匹配操作 
  9.         Matcher m = twopart.matcher(s); 
  10.         if (m.matches()) { 
  11.             //m.group(1) 和 m.group(2) 存储分割后的子串 
  12.             System.out.println(s + " matches; first part is " + m.group(1) + 
  13.                     ", second part is " + m.group(2) + "."); 
  14.         } else { 
  15.             System.out.println(s + " does not match."); 
  16.         } 
  17.     } 
  18.  
  19.     public static void main(String[] args) { 
  20.         checkString("123-4567");  // 匹配 
  21.         checkString("s-tar");    // 字母序列,不匹配 
  22.         checkString("123-");    // "-"右侧的数字串为空,不匹配 
  23.         checkString("-4567");    // "-"左侧的数字串为空,不匹配 
  24.         checkString("123-4567-890");    // 存在两个"-",不匹配 
  25.     } 

上述程序的运行结果为:

来源:鸭哥聊Java内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯