Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Java: Replace a string from multiple replaced strings to multiple substitutes

Java: Replace a string from multiple replaced strings to multiple substitutes

作者头像
绿巨人
发布于 2018-05-16 09:56:13
发布于 2018-05-16 09:56:13
76700
代码可运行
举报
文章被收录于专栏:绿巨人专栏绿巨人专栏
运行总次数:0
代码可运行

Provide helper methods to replace a string from multiple replaced strings to multiple substitutes

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import java.util.regex.Matcher;
import java.util.regex.Pattern;


public class StringHelper {
    
    /**
     * This is test method to replace a string from:
     * aaa > zzz
     * \t > /t
     * \r > /r
     * \n > /n
     */
    public static void run()
    {
        
        String[] replacedStrings = new String[] {"aaa", "\t", "\r", "\n"};
        String[] replacements = new String[] {"zzz", "/t", "/r", "/n"};
    
        Pattern pattern = getReplacePattern(replacedStrings);
        
        // The result is "zzza/tb/rc/nd/te/nf"
        System.out.println(replace("aaaa\tb\rc\nd\te\nf", pattern, replacedStrings, replacements));
        
        // The result is "zzza/tb/rc/nd/te/nf/r"
        System.out.println(replace("aaaa\tb\rc\nd\te\nf\r", pattern, replacedStrings, replacements));
    }
    
    /**
     * Return a Pattern instance from a specific replaced string array.
     * @param replacedStrings replaced strings
     * @return a Pattern instance
     */
    public static Pattern getReplacePattern(String[] replacedStrings)
    {
        if (replacedStrings == null || replacedStrings.length == 0) return null;
        
        String regex = "";
        for (String replacedString : replacedStrings)
        {
            if (regex.length() != 0)
            {
                regex = regex + "|";
            }
            regex = regex + "(" + replacedString + ")";
        }
        regex = regex + "";

        return Pattern.compile(regex, Pattern.DOTALL | Pattern.MULTILINE);
    }
    

    /**
     * Replace a string.
     * @param value the string.
     * @param pattern the Pattern instance.
     * @param replacedStrings the replaced string array.
     * @param replacements the replacement array.
     * @return
     */
    public static String replace(String value, Pattern pattern, String[] replacedStrings, String[] replacements)
    {
        if (pattern == null) return value;
        if (replacedStrings == null || replacedStrings.length == 0) return value;
        if (replacements == null || replacements.length == 0) return value;
        
        if (replacedStrings.length != replacements.length) 
        {
            throw new RuntimeException("replacedStrings length must same as replacements length.");
        }
        
        Matcher matcher = pattern.matcher(value);
        StringBuffer buffer = new StringBuffer();
        int lastIndex = 0;
        
        while (matcher.find()) {
            buffer.append(value.subSequence(lastIndex,  matcher.start()));
            lastIndex = matcher.end();

            String group = matcher.group();
             
            for (int i = 0; i < replacedStrings.length; i++)
            {
                if (group.equals(replacedStrings[i]))
                {
                    buffer.append(replacements[i]);
                    break;
                }
            }
         }
         
         buffer.append(value.subSequence(lastIndex, value.length()));
         return buffer.toString();
    }
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2016-04-01 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
Vue3如何优雅的跨组件通信🚀🚀🚀
开发中经常会遇到跨组件通信的场景。props 逐层传递的方法实在是太不优雅了,所以今天总结下可以更加简单的跨组件通信的一些方法。
萌萌哒草头将军
2023/11/12
8250
Vue3如何优雅的跨组件通信🚀🚀🚀
百度某部门一面原题(附答案)
这次的百度面试挺紧张的,在写算法题的时候脑子都有点空白,还是按照脑海中那点残存的算法技巧才写出来,不至于太尴尬,以及第一次面试百度这种级别的公司,难免出现了一些平常不至于出现的问题或没注意的缺点,在这里分享给大家。
winty
2023/11/16
2170
百度某部门一面原题(附答案)
百度一面,直接问痛我
这次的百度面试挺紧张的,在写算法题的时候脑子都有点空白,还是按照脑海中那点残存的算法技巧才写出来,不至于太尴尬,以及第一次面试百度这种级别的公司,难免出现了一些平常不至于出现的问题或没注意的缺点,在这里分享给大家。
zz_jesse
2023/09/20
1660
百度一面,直接问痛我
vue2升级vue3: Event Bus 替代方案
在看 https://v3-migration.vuejs.org/breaking-changes/events-api.html
周陆军博客
2022/06/25
1.6K0
2023前端vue面试题汇总_2023-02-27
有五种,分别是 State、 Getter、Mutation 、Action、 Module
用户10377014
2023/02/27
1.2K0
腾讯前端一面常考vue面试题汇总2
vue构建函数调用_init方法,但我们发现本文件中并没有此方法,但仔细可以看到文件下方定定义了很多初始化方法
bb_xiaxia1998
2023/01/04
6790
从一道面试题简单谈谈发布订阅和观察者模式
今天的话题是javascript中常被提及的「发布订阅模式和观察者模式」,提到这,我不由得想起了一次面试。记得在去年的一次求职面试过程中,面试官问我,“你在项目中是怎么处理非父子组件之间的通信的?”。我答道,“有用到vuex,有的场景也会用EventEmitter2”。面试官继续问,“那你能手写代码,实现一个简单的EventEmitter吗?”
程序员白彬
2020/07/10
1K0
从一道面试题简单谈谈发布订阅和观察者模式
前端高频手写面试题
then 方法返回一个新的 promise 实例,为了在 promise 状态发生变化时(resolve / reject 被调用时)再执行 then 里的函数,我们使用一个 callbacks 数组先把传给then的函数暂存起来,等状态改变时再调用。
helloworld1024
2022/12/16
1.1K0
如果面试官让你讲讲发布订阅设计模式?
有小伙伴问,该如何学习设计模式,设计模式本身是一些问题场景的抽象解决方案,死记硬背肯定不行,无异于搭建空中楼阁,所以得结合实际,从解决问题角度去思考、举一反三,如此便能更轻松掌握知识点。
小东同学
2022/07/29
2.7K0
如果面试官让你讲讲发布订阅设计模式?
Vue3组件通信相关的知识梳理
我们知道vue3的Composition Api是它几个最大亮点之一,所以下文都是在setup中演示代码的实现。后面会以开发几个简单form组件为例子来演示。
前端达人
2021/08/10
3.6K0
Vue3组件通信相关的知识梳理
自己实现一个Electron跨进程消息组件(新书自荐)
我们知道开发Electron应用,难免要涉及到跨进程通信,以前Electron内置了remote模块,极大的简化了跨进程通信的开发工作,但这也带来了很多问题,具体的细节请参与我之前写的文章:
liulun
2021/12/21
1.3K0
自己实现一个Electron跨进程消息组件(新书自荐)
Vue之全局事件总线和消息订阅与发布
之前我们实现了子组件向父组件传递数据,很明显,这是不够的,看完这篇博客,无论哪两个组件之间传递和接收数据都没有问题!
程序狗
2021/12/14
8110
Vue事件总线(EventBus)使用详细介绍
vue组件非常常见的有父子组件通信,兄弟组件通信。而父子组件通信就很简单,父组件会通过 props 向下传数据给子组件,当子组件有事情要告诉父组件时会通过 $emit 事件告诉父组件。今天就来说说如果两个页面没有任何引入和被引入关系,该如何通信了?
Javanx
2019/09/04
2K0
Vue事件总线(EventBus)使用详细介绍
高频js手写题之实现数组扁平化、深拷贝、总线模式
古人学问无遗力,少壮工夫老始成。纸上得来终觉浅,绝知此事要躬行。看懂一道算法题很快,但我们必须将这道题的思路理清、手写出来。
helloworld1024
2022/10/06
3820
Vue3 使用 mitt 实现跨组件通信
emitter.on 第一个参数是消息 key ,第二个参数可以是基本数据、对象、函数!
訾博ZiBo
2025/01/06
1130
Vue3 使用 mitt 实现跨组件通信
JS手撕(七) 事件总线
学习JS的话,就一定会接触到事件的概念。比如给一个按钮绑定点击事件,绑定事件后,点击按钮会触发回调函数。
赤蓝紫
2023/01/01
7880
聊一聊如何在Vue中使用事件总线( Event Bus)进行组件间通信
跨通信是应用程序中组件之间的交互。这有助于应用程序的不同部分之间的顺畅协作。其重要性体现在以下几个方面:
前端达人
2023/10/21
1.5K0
聊一聊如何在Vue中使用事件总线( Event Bus)进行组件间通信
BuildAdmin13:区区重新加载,vue居然用了mitt事件总线库
关于弹出框,前几篇主要讲了如何渲染弹出框标签、实现弹出框的弹出位置、触发弹出框以及弹出框组件和tabs组件的数据交互。
叫我阿柒啊
2024/02/10
3860
BuildAdmin13:区区重新加载,vue居然用了mitt事件总线库
Vue 组件间通信的几种方式
Vue 遵循单向数据流的原则,状态会从父组件传递给子组件,避免子组件意外改变父组件状态导致的混乱逻辑。
前端西瓜哥
2022/12/21
2K0
Vue组件通信的三种方式
我们都知道Vue是一款渐进式的js框架,在开发大型应用的时候,Vue官方推荐你使用组件化进行开发,即每一个页面都是一个组件,一个组件内包含了一个或多个组件,下面举一个简单的例子描述一下Vue中的组件。
姜同学
2022/10/27
5090
Vue组件通信的三种方式
相关推荐
Vue3如何优雅的跨组件通信🚀🚀🚀
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验