处理一个字符串多个分隔符

2024-06-04 12:58

本文主要是介绍处理一个字符串多个分隔符,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在之前的项目需求中,遇到一个字符串一种字符标识为1种类型。

         如字符串: a#aa|b#bb$c#aaa。。。这种

其中

#号一组的有:[a,aa,bb,aaa]

分组为$有:[c]

分组|的有:[b]

.......

里面规则是:第一个符号前面没有标识符则列入后面的分组,后面字符串没有标识符则列入前面标识分组,其余中间部分按前面标识符分组

如(前无):a 前面没有标识符,则取后面#号

如2(后无):aaa后面没有标识符,则取前面

如3(中间):aa前面#号,则是#号分组,b前面是|,这是|号分组

以此类推。。。。


代码如下:



/**** @param src 操作的符号* @param symbol 操作的符号* */public static Map<String, List<String>> byteOpare(char[] src, char[] symbol) {Map<String, List<String>> result = new HashMap<String, List<String>>();int size = src.length;String prefix = null, suffix = null;String buf = "";for (int i = 0; i < size; i++) {// 第一个字符和最后的字符特殊处理char b = src[i];if (i == 0) {if (compareSymbol(b, symbol)) { // 特殊字符prefix = b + "";} else { // 普通字符prefix = null;buf += b;}} else if (i == size - 1) { // 最后一个特殊处理if (!compareSymbol(b, symbol)) { // 特殊字符buf += b;}put(result, prefix, buf);} else { // 中间数据if (compareSymbol(b, symbol)) { // 特殊字符suffix = b + "";if (prefix == null) { // 没有前缀// 数字按后缀处理// 并且按后缀保存put(result, suffix, buf);} else {// 有前缀按前缀的来处理put(result, prefix, buf);}prefix = suffix; // 处理完后将后缀变成前缀suffix = null;buf = "";} else {buf += b;}}}return result;}/*** 添加至Map* @param result* @param key* @param value*/public static void put(Map<String, List<String>> result, String key, String value) {if(StringUtil.isNullOrEmpty(key)) {key = "empty";}if (result.containsKey(key)) {((List<String>) result.get(key)).add(value);} else {List<String> values = new ArrayList<String>();values.add(value);result.put(key, values);}}/*** 是否包含特殊字符* */public static boolean compareSymbol(char target, char[] symbol) {for (char s : symbol) {if (s == target) {return true;}}return false;}


则以下为测试方法:

String str = "a#aa|b#bb$c#aaa";Map<String, List<String>> result = new Demo().byteOpare(str.toCharArray(), new char[] { '#', '$', '|', 'N' });for (Entry<String, List<String>> entry : result.entrySet()) {String key = entry.getKey();System.out.print("分组为" + key + "[");for (String value : entry.getValue()) {System.out.print(value + ",");}System.out.println("]");}


打印结果为:

分组为#[a,aa,bb,aaa,]
分组为$[c,]
分组为|[b,]


值得注意的是,如果没有任意标识符的话,Map中的Key为:empty



希望有用上的码友。Mark下

害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞害羞


这篇关于处理一个字符串多个分隔符的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1030152

相关文章

Java对象和JSON字符串之间的转换方法(全网最清晰)

《Java对象和JSON字符串之间的转换方法(全网最清晰)》:本文主要介绍如何在Java中使用Jackson库将对象转换为JSON字符串,并提供了一个简单的工具类示例,该工具类支持基本的转换功能,... 目录前言1. 引入 Jackson 依赖2. 创建 jsON 工具类3. 使用示例转换 Java 对象为

Python自动化处理手机验证码

《Python自动化处理手机验证码》手机验证码是一种常见的身份验证手段,广泛应用于用户注册、登录、交易确认等场景,下面我们来看看如何使用Python自动化处理手机验证码吧... 目录一、获取手机验证码1.1 通过短信接收验证码1.2 使用第三方短信接收服务1.3 使用ADB读取手机短信1.4 通过API获取

golang字符串匹配算法解读

《golang字符串匹配算法解读》文章介绍了字符串匹配算法的原理,特别是Knuth-Morris-Pratt(KMP)算法,该算法通过构建模式串的前缀表来减少匹配时的不必要的字符比较,从而提高效率,在... 目录简介KMP实现代码总结简介字符串匹配算法主要用于在一个较长的文本串中查找一个较短的字符串(称为

Python自动化Office文档处理全攻略

《Python自动化Office文档处理全攻略》在日常办公中,处理Word、Excel和PDF等Office文档是再常见不过的任务,手动操作这些文档不仅耗时耗力,还容易出错,幸运的是,Python提供... 目录一、自动化处理Word文档1. 安装python-docx库2. 读取Word文档内容3. 修改

Python自动化办公之合并多个Excel

《Python自动化办公之合并多个Excel》在日常的办公自动化工作中,尤其是处理大量数据时,合并多个Excel表格是一个常见且繁琐的任务,下面小编就来为大家介绍一下如何使用Python轻松实现合... 目录为什么选择 python 自动化目标使用 Python 合并多个 Excel 文件安装所需库示例代码

Java实现检查多个时间段是否有重合

《Java实现检查多个时间段是否有重合》这篇文章主要为大家详细介绍了如何使用Java实现检查多个时间段是否有重合,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录流程概述步骤详解China编程步骤1:定义时间段类步骤2:添加时间段步骤3:检查时间段是否有重合步骤4:输出结果示例代码结语作

Java中String字符串使用避坑指南

《Java中String字符串使用避坑指南》Java中的String字符串是我们日常编程中用得最多的类之一,看似简单的String使用,却隐藏着不少“坑”,如果不注意,可能会导致性能问题、意外的错误容... 目录8个避坑点如下:1. 字符串的不可变性:每次修改都创建新对象2. 使用 == 比较字符串,陷阱满

Java判断多个时间段是否重合的方法小结

《Java判断多个时间段是否重合的方法小结》这篇文章主要为大家详细介绍了Java中判断多个时间段是否重合的方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录判断多个时间段是否有间隔判断时间段集合是否与某时间段重合判断多个时间段是否有间隔实体类内容public class D

IDEA编译报错“java: 常量字符串过长”的原因及解决方法

《IDEA编译报错“java:常量字符串过长”的原因及解决方法》今天在开发过程中,由于尝试将一个文件的Base64字符串设置为常量,结果导致IDEA编译的时候出现了如下报错java:常量字符串过长,... 目录一、问题描述二、问题原因2.1 理论角度2.2 源码角度三、解决方案解决方案①:StringBui

linux下多个硬盘划分到同一挂载点问题

《linux下多个硬盘划分到同一挂载点问题》在Linux系统中,将多个硬盘划分到同一挂载点需要通过逻辑卷管理(LVM)来实现,首先,需要将物理存储设备(如硬盘分区)创建为物理卷,然后,将这些物理卷组成... 目录linux下多个硬盘划分到同一挂载点需要明确的几个概念硬盘插上默认的是非lvm总结Linux下多