每当出现“”时,我都尝试拆分字符串,例如语句test abc。然后,将每个单词中的第一个字母从头到尾移动。我将字母移动到使用原始字符串
String text = JOptionPane.showInputDialog(null,"Skriv in en normal text:"); char firstLetter = text.charAt(0); normal = text.substring(1,text.length()+0) + firstLetter;
所以我的问题是,我将如何分割字符串,然后开始在分割字符串的每个部分中移动字母?
您不必split为此进行-transform-join;replaceAll一步就能做到。
split
replaceAll
String text = "Skriv in en normal text:"; text = text.replaceAll("(\\s*)(\\w)(\\w+)", "$1$3$2"); System.out.println(text); // prints "krivS ni ne ormaln extt:"
正则表达式基本上分为3组:
\1 : (\s*) : any optional preceding whitespace \2 : (\w) : the head portion of each "word" \3 : (\w+) : any tail portion of each "word"
那么,作为替换字符串使它明显和清晰,切换\2和\3周围。
\2
\3
因此,应该清楚的是,replaceAll使用捕获组是解决此问题的最佳方法,也是最易读的解决方案,但是该正则表达式取决于问题规范。请注意,例如,上述正则表达式将转换text:为extt:(即,将结肠保留在原处)。
text:
extt:
以下变体在空白处分割\s,并对非空白字符序列的头/尾重新排序\S。这应该与您当前的split(" ")-transform- join解决方案相同:
\s
\S
split(" ")
String text = "bob: !@#$ +-"; text = text.replaceAll("(\\s*)(\\S)(\\S+)", "$1$3$2"); System.out.println(text); // prints "ob:b @#$! -+"
这种变化可以切换\w+由单词边界包围的任何单词字符序列\b。如果这是您的需要,那么这是该工作最简单,最易读的解决方案。
\w+
\b
String text = "abc:def!ghi,jkl mno"; text = text.replaceAll("\\b(\\w)(\\w+)\\b", "$2$1"); System.out.println(text); // prints "bca:efd!hig,klj nom"
Matcher.replaceAll