删除ruby中的子串
发布时间:2020-12-17 03:51:13 所属栏目:百科 来源:网络整理
导读:给定一串字符串, array1 = ["abcdwillbegoneabcccc","cdefwilbegokkkabcdc"] 和另一个由例如图案组成的字符串阵列[ “ABCD”,“求的[o | P] N”,“BCC”,“CDEF”,“H * gxwy”] 任务是删除与任何模式字符串匹配的子字符串.例如,此案例的示例输出应为: ["wi
给定一串字符串,
array1 = ["abcdwillbegoneabcccc","cdefwilbegokkkabcdc"] 和另一个由例如图案组成的字符串阵列[ “ABCD”,“求的[o | P] N”,“BCC”,“CDEF”,“H * gxwy”] 任务是删除与任何模式字符串匹配的子字符串.例如,此案例的示例输出应为: ["willbegonea","wilbegokkk"] 因为我们已经删除了匹配其中一个模式的子串(根据发生的位置适当的匹配或匹配).假设一个或两个匹配将始终发生在array1中每个字符串的开头或结尾处. 在ruby中对上述优雅解决方案的任何想法? 解决方法
如何建立一个正则表达式?
array1 = ["abcdwillbegoneabcccc","cdefwilbegokkkabcdc"] to_remove = ["abcd","beg[o|p]n","bcc","cdef","h*gxwy"] reg = Regexp.new(to_remove.map{ |s| "(#{s})" }.join('|')) #=> /(abcd)|(beg[o|p]n)|(bcc)|(cdef)|(h*gxwy)/ array1.map{ |s| s.gsub(reg,'') } #=> ["willeacc","wilbegokkkc"] 请注意,我的结果与您的结果不同 ["willbegonea","wilbegokkk"] 但我认为我的是正确的,它从原版中删除了“abcd”,“begon”和“bcc”,这似乎是想要的. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |