文字列から開始と終了の二重引用符( ")をトリミングしたいと思います。
Javaでこれを実現するにはどうすればよいですか?ありがとう!
このために^\"|\"$
のパターンで String#replaceAll()
を使用できます。
例えば。
string = string.replaceAll("^\"|\"$", "");
正規表現の詳細については、 http://regular-expression.info を参照してください。
とは言っても、これはCSVパーサーを発明しようとしているようなものです。もしそうなら、 OpenCSV のような既存のライブラリを探すことをお勧めします。
文字列から最初の文字と最後の文字を削除するには、次を使用します。
myString = myString.substring(1, myString.length()-1);
グアバを使用すると、よりエレガントにCharMatcher.is('\"').trimFrom(mystring);
を書くことができます
これは、文字列の先頭と末尾から二重引用符を取り除くための最良の方法です。
someString.replace (/(^")|("$)/g, '')
二重引用符が先頭と末尾にのみ存在する場合、これのような単純なコードは完全に機能します。
string = string.replace("\"", "");
また、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
このメソッドは、私の例に示すように、引用符付き文字列と引用符なし文字列の両方で機能します。唯一の欠点は、厳密にmatched引用符を検索せず、先頭と末尾の引用文字のみ(つまり、"partially
と"fully"
引用符で囲まれた文字列)。
まず、文字列が二重引用符で囲まれているかどうかを確認し、二重引用符で囲まれている場合は削除します。実際に二重引用符で囲まれていることがわかっている場合は、条件をスキップできます。
if (string.length() >= 2 && string.charAt(0) == '"' && string.charAt(string.length() - 1) == '"')
{
string = string.substring(1, string.length() - 1);
}
Kotlinでは、 String.removeSurrounding(delimiter:CharSequence) を使用できます
例えば。
string.removeSurrounding("\"")
指定されたdelimiter文字列を、(== ---で始まり、delimiter。それ以外の場合は、この文字列を変更せずに返します。
ソースコードは次のようになります。
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
}
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;
}
以下のパターンをJava.util.regex.Matcher
と共に使用すると、文字列内の二重引用符の発生に影響を与えることなく、二重引用符の間の任意の文字列に一致します。
"[^\"][\\p{Print}]*[^\"]"
s.stripPrefix("\"").stripSuffix("\"")
これは、文字列の最初と最後に引用符があるかどうかに関係なく機能します。
編集:申し訳ありませんが、Scalaのみ
Javaで文字列の先頭と末尾から1つ以上の二重引用符を削除するには、正規表現ベースのソリューションを使用する必要があります。
String result = input_str.replaceAll("^\"+|\"+$", "");
単一引用符も削除する必要がある場合:
String result = input_str.replaceAll("^[\"']+|[\"']+$", "");
NOTE:文字列に"
が含まれている場合、この方法では問題が発生する可能性があります(例:"Name": "John"
=> Name": "John
)。
こちらのJavaデモ をご覧ください:
String input_str = "\"'some string'\"";
String result = input_str.replaceAll("^[\"']+|[\"']+$", "");
System.out.println(result); // => some string
編集:両方が存在する場合にのみこれが機能することを指定する必要があることに気付きました。それ以外の場合、文字列は引用符で囲まれているとは見なされません。このようなシナリオは、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\""
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);
}