文字列から最初と最後の二重引用符( ")を削除したいの
ですが、Javaでこれを実現するにはどうすればよいですか?ありがとうございます。
19 に答える
String#replaceAll()
このためのパターンで使用できます^\"|\"$
。
例えば
string = string.replaceAll("^\"|\"$", "");
正規表現の詳細については、 http: //regular-expression.infoを参照してください。
そうは言っても、これは、CSVパーサーを発明しようとしているようなにおいがします。もしそうなら、 OpenCSVなどの既存のライブラリを探すことをお勧めします。
文字列から最初の文字と最後の文字を削除するには、次を使用します。
myString = myString.substring(1, myString.length()-1);
ApacheでもStringUtils.strip()
:
StringUtils.strip(null, *) = null
StringUtils.strip("", *) = ""
StringUtils.strip("abc", null) = "abc"
StringUtils.strip(" abc", null) = "abc"
StringUtils.strip("abc ", null) = "abc"
StringUtils.strip(" abc ", null) = "abc"
StringUtils.strip(" abcyx", "xyz") = " abc"
それで、
final String SchrodingersQuotedString = "may or may not be quoted";
StringUtils.strip(SchrodingersQuotedString, "\""); //quoted no more
このメソッドは、私の例に示すように、引用符で囲まれた文字列と引用符で囲まれていない文字列の両方で機能します。唯一の欠点は、厳密に一致する"partially
引用符を検索せず、先頭と末尾の引用符文字のみを検索することです(つまり、引用符で囲まれた文字列との区別がありません"fully"
)。
二重引用符が最初と最後にのみ存在する場合、このような単純なコードは完全に機能します。
string = string.replace("\"", "");
これは、文字列の最初と最後から二重引用符を取り除くために私が見つけた最良の方法です。
someString.replace (/(^")|("$)/g, '')
まず、文字列が二重引用符で囲まれているかどうかを確認し、二重引用符で囲まれている場合は削除します。二重引用符で囲まれていることが実際にわかっている場合は、条件をスキップできます。
if (string.length() >= 2 && string.charAt(0) == '"' && string.charAt(string.length() - 1) == '"')
{
string = string.substring(1, string.length() - 1);
}
Guavaを使用すると、よりエレガントに書くことができますCharMatcher.is('\"').trimFrom(mystring);
Kotlin
Kotlinでは、String.removeSurrounding(delimiter:CharSequence)を使用できます
例えば
string.removeSurrounding("\"")
指定された区切り文字列は、区切り文字で始まり、区切り文字で終わる場合にのみ、この文字列の先頭と末尾の両方から削除されます。それ以外の場合は、この文字列を変更せずに返します。
ソースコードは次のようになります。
public fun String.removeSurrounding(delimiter: CharSequence): String = removeSurrounding(delimiter, delimiter)
public fun String.removeSurrounding(prefix: CharSequence, suffix: CharSequence): String {
if ((length >= prefix.length + suffix.length) && startsWith(prefix) && endsWith(suffix)) {
return substring(prefix.length, length - suffix.length)
}
return this
}
私はこれと同じくらい単純なものを使用しています:
if(str.startsWith("\"") && str.endsWith("\""))
{
str = str.substring(1, str.length()-1);
}
編集:両方が存在する場合にのみこれが機能することを指定する必要があることに気づきました。それ以外の場合、文字列は引用符で囲まれているとは見なされません。このようなシナリオは、CSVファイルを操作するときに表示されました。
org.apache.commons.lang3.StringUtils.unwrap("\"abc\"", "\"") = "abc"
org.apache.commons.lang3.StringUtils.unwrap("\"abc", "\"") = "\"abc"
org.apache.commons.lang3.StringUtils.unwrap("abc\"", "\"") = "abc\""
Javaで文字列の最初と最後から1つ以上の二重引用符を削除するには、正規表現ベースのソリューションを使用する必要があります。
String result = input_str.replaceAll("^\"+|\"+$", "");
一重引用符も削除する必要がある場合:
String result = input_str.replaceAll("^[\"']+|[\"']+$", "");
注:文字列に"
内部が含まれている場合、このアプローチは問題を引き起こす可能性があります(例:"Name": "John"
=> Name": "John
)。
ここでJavaデモを参照してください:
String input_str = "\"'some string'\"";
String result = input_str.replaceAll("^[\"']+|[\"']+$", "");
System.out.println(result); // => some string
以下のパターンは、と一緒に使用するとjava.util.regex.Matcher
、文字列内の二重引用符の出現に影響を与えることなく、二重引用符の間の任意の文字列に一致します。
"[^\"][\\p{Print}]*[^\"]"
Matcher m = Pattern.compile("^\"(.*)\"$").matcher(value);
String strUnquoted = value;
if (m.find()) {
strUnquoted = m.group(1);
}
@brcolowの回答を少し変更する
if (string != null && string.length() >= 2 && string.startsWith("\"") && string.endsWith("\"") {
string = string.substring(1, string.length() - 1);
}
public String removeDoubleQuotes(String request) {
return request.replace("\"", "");
}
private static String removeQuotesFromStartAndEndOfString(String inputStr) {
String result = inputStr;
int firstQuote = inputStr.indexOf('\"');
int lastQuote = result.lastIndexOf('\"');
int strLength = inputStr.length();
if (firstQuote == 0 && lastQuote == strLength - 1) {
result = result.substring(1, strLength - 1);
}
return result;
}
Scala
s.stripPrefix("\"").stripSuffix("\"")
これは、文字列の先頭または末尾に引用符があるかどうかに関係なく機能します。
編集:申し訳ありませんが、Scalaのみ
各二重引用符のインデックスを見つけて、そこに空の文字列を挿入します。
Groovy
groovyの正規表現を使用して、文字列から部分文字列を減算できます。
String unquotedString = theString - ~/^"/ - ~/"$/