gpt4 book ai didi

java - 手动字符串查找和替换

转载 作者:行者123 更新时间:2023-12-01 13:46:50 25 4
gpt4 key购买 nike

给定一个字符串I #eat# #hamburgers#和一个 StringBuilder eat: [eat, consume, like] hamburgers: [hamburgers, spinach, bananas] ,我想用从词库中随机选择的单词随机替换散列标记中的单词,以便诸如 I like bananas 之类的短语和I consume spinach将被生成。已经编写了给定标记(即吃、汉堡包)的情况下随机选择另一个单词的代码。

我需要使用这个正则表达式 #[^#]+# 来查找哈希标记包含的初始字符串中的单词,将它们传递给替换方法,然后将它们的随机关联放回初始字符串内。我尝试使用 StringTokenizer,但意识到它不是完成这项工作的工具。

我需要以某种方式提取哈希标记中的第一个单词,并将其传递给调用其替换的方法,然后再以这种方式调用方法 archetypeString(#[^#]+#, replacement) ,以便当循环再次运行时,单词抓取器和传递器方法和替换方法都将处理第二个哈希单词。

分词器死胡同:

StringTokenizer stt = new StringTokenizer(archetype);
while(stt.hasMoreTokens()){
String temp = stt.nextToken();
if(temp.charAt(0)=='#');
}

和 getPhrase 方法:

public List<String> getPhrases(StringBuilder fileContent, String token) {
StreamTokenizer tokenizer = new StreamTokenizer(new StringReader(fileContent.toString()));
List<String> list = new ArrayList<String>();
try {
while (tokenizer.nextToken() != StreamTokenizer.TT_EOF) {
if (tokenizer.sval.equals(token)) {
tokenizer.nextToken(); // '['
do {
tokenizer.nextToken(); // go to the number
list.add(String.valueOf(tokenizer.sval));
} while (tokenizer.nextToken() == ',');
break;
}
}
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return list;
}

最佳答案

I need to use this regex #[^#]+# to find words within the initial string contained by hashmarks, pass them to the replace method, and then put their random correlates back inside the initial string. I tried using StringTokenizer, but realized it's not the tool for the job.

从你的问题中并不清楚这是否是一些虐待狂家庭作业的一部分,或者只是你想到的解决你试图解决的任何问题的第一种方法。这不是一个正则表达式问题,也不是一个 StringTokenizer 问题。

查看 String.format() 以及 Formatter 的格式化功能。我不明白如果您的目标是随机生成下一个字符串,为什么您需要知道生成的最后一个字符串是什么。只需选择一个新的随机值并使用 String.format() 对其进行格式化即可。

--

阅读您对此答案的评论并查看您提到的问题后,我将提出一些建议。

(1) 从一个或两个更简单的编码作业开始,一些没有正则表达式的东西。确保您完全理解以下概念:实例变量。变量范围。公共(public)方法与私有(private)方法。将参数传递给方法,并从方法返回值。就这么多,你就可以做很多事情。在您了解所有这些之前,您不需要研究继承,我建议您不要尝试。

(2) 对于至少前 5 个编码作业,请确保您已写出您的程序将作为数据提供的内容以及它应产生的输出。列出某人单独给你的任何约束(必须使用 X 类,必须显示错误消息,等等)。

(3) 将左大括号和右大括号单独放在行上;将每个左大括号与缩进相同量的右大括号相匹配。将每对大括号内的代码再向右缩进 2 或 3 个空格。这意味着其他括号对内的括号对将进一步缩进。我知道这不是您看到大多数代码的方式,很多人会告诉您这是“错误的”。但是,在您熟悉范围以及代码中的给定位置是在方法或循环内部还是外部之前,我认为最好给自己提供这些额外的视觉提示。对于不熟悉其他做事方式的人来说,这是最简单的。

(4) 在此发帖时请注意您的条款。在您提到的另一个问题中,您说它是关于继承的,但它使用“implements”,表明它正在实现一个接口(interface),而不是从一个类继承。如果您弄错术语,我们这些试图帮助您的人就会感到困惑。

(5) 当您在此处发布时:发布整个程序(这些早期作业的总行数应低于 100 行,没有理由不发布全部内容)。确保它正确缩进;使用空格而不是制表符。在文本中,也许也在注释中,指出代码中您似乎有问题的地方(如果您知道的话)。如果有错误消息,请发布完整的错误消息(不要告诉我们它是什么,也不要尝试为我们解释它)。处理你的代码,直到你有一个具体的问题:为什么我会在这里收到编译错误?为什么我得到(或无法得到)这个输出?程序输出 X 但我期望 Y,这是为什么?等等

我们不是教程店;我们是一家教程店。我们大多数人都需要指导来学习编程,而除了这里之外,您还需要在其他地方获得大部分指导。鉴于您的问题具体且合理,并且您并不期望我们提供指导,我们愿意帮助您解决问题。就其本身而言,“我迷路了,需要帮助”有点超出了 StackOverflow 的正常操作方式。

关于java - 手动字符串查找和替换,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20305120/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com