RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 754148
Accepted
IC_
IC_
Asked:2020-12-05 21:11:54 +0000 UTC2020-12-05 21:11:54 +0000 UTC 2020-12-05 21:11:54 +0000 UTC

爪哇。正则表达式替换

  • 772

我通过join("|").

任务,每个模式可以满足N个匹配
例如: (и\\s*\\.*\\s*т\\s*\\.?\\s*д\\s*\\.)
每个匹配被锤击成HashMap<String, String>,其中 <Hash, Match>
将每个匹配替换为源字符串中的一个哈希。

问题:由于某种原因,它只Matcher.find()执行一次循环迭代,并用|相同的哈希替换管道中的所有模式。

在这种情况下,除了手动编译单词列表之外该怎么做?

UPD

此任务的简化示例 ( https://ideone.com/d1UhRh ):

import java.util.regex.Matcher;
import java.util.regex.Pattern;
import java.util.HashMap;

public class Main
{
   static void processString(String line)
   {
      Pattern p = Pattern.compile("(1\\%?|2|3|4)"); // 5 Вариантов паттернов для теста
      Matcher m = p.matcher(line);          // Естественно в реальной задаче намного больше

      HashMap<String, String> map = new HashMap<>();

      int i = 0;
      while (m.find()) {
        // Здесь я ожидаю 5 итераций для каждого вхождения 1, 1%, 2, 3, 4 и замены их на ААА1, ААА1%, ААА2 и т.д.
        // Эти вхождения добавить в HashMap (map) ниже
        i++;
         System.out.println("Нужно заменить " + m.group() + " на AAA" + i);
         // Добавить $1 в хэшмап !!
         // map.put(?)
         // То есть если я передаю все 5 паттернов, то в map должно быть 5 записей
         line = m.replaceAll("AAA$1");
      }

      System.out.println("\n\n" + line);
   }

   public static void main(String[] args)
   {
      processString(" 1  2  3  4  4  2  1%  1%  1  2  3 ");
   }
}

结果:

AAA1 AAA1 AAA1 AAA1 AAA1 AAA1 AAA1 AAA1 AAA1 AAA1 AAA1

预期结果:

AAA1 AAA2 AAA3 AAA4 AAA4 AAA2 AAA1% AAA1% AAA1 AAA2 AAA3

UPD 2
增加了关于 HashMap 问题的说明

java
  • 1 1 个回答
  • 10 Views

1 个回答

  • Voted
  1. Best Answer
    default locale
    2020-12-05T22:07:01Z2020-12-05T22:07:01Z

    搜索只执行一次,因为它Matcher.replaceAll替换了源字符串中的所有匹配项,然后重新启动matcher:

    此方法首先重置此匹配器。然后它扫描输入序列以查找模式的匹配项。

    如果您需要依次替换出现,那么您可以Matcher.appendReplacement使用Matcher.appendTail:

    StringBuffer sb = new StringBuffer();
    while (m.find()) {
        i++;
        m.appendReplacement(sb, "AAA"+i);
    }
    m.appendTail(sb);
    System.out.println("\n\n" + sb);
    

    如果您需要将事件保存在 中Map,那么您可以处理每个事件并记住哈希:

    HashMap<String, String> map = new HashMap<String,String>();
    StringBuffer sb = new StringBuffer();
    while (m.find()) {      
        String group = m.group();
        String replacement;
        if(map.containsKey(group)) {
           //уже есть хэш
           replacement = map.get(group);
        } else {
           //создаем  и запоминаем новый хэш
           i++;
           replacement = "AAA"+i;
           map.put(group, replacement);
        }
        m.appendReplacement(sb, replacement);
    }
    m.appendTail(sb);
    

    在这种情况下,迭代次数将等于出现次数,而不是唯一出现次数。

    这里,为方便起见,使用了映射Совпадение -> Хэш,而不是Хэш -> Совпадение像问题中那样,但如果需要,也可以并行执行反向映射。

    添加什么的处理1并1%归结为一个哈希来品尝。或者使用表达式(1|2|3|4)并保持百分比不变。

    Ideone 上的示例。

    • 4

相关问题

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    Python 3.6 - 安装 MySQL (Windows)

    • 1 个回答
  • Marko Smith

    C++ 编写程序“计算单个岛屿”。填充一个二维数组 12x12 0 和 1

    • 2 个回答
  • Marko Smith

    返回指针的函数

    • 1 个回答
  • Marko Smith

    我使用 django 管理面板添加图像,但它没有显示

    • 1 个回答
  • Marko Smith

    这些条目是什么意思,它们的完整等效项是什么样的

    • 2 个回答
  • Marko Smith

    浏览器仍然缓存文件数据

    • 1 个回答
  • Marko Smith

    在 Excel VBA 中激活工作表的问题

    • 3 个回答
  • Marko Smith

    为什么内置类型中包含复数而小数不包含?

    • 2 个回答
  • Marko Smith

    获得唯一途径

    • 3 个回答
  • Marko Smith

    告诉我一个像幻灯片一样创建滚动的库

    • 1 个回答
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Алексей Шиманский 如何以及通过什么方式来查找 Javascript 代码中的错误? 2020-08-03 00:21:37 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    user207618 Codegolf——组合选择算法的实现 2020-10-23 18:46:29 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5