String [] öğesini java'da virgülle ayrılmış dizeye dönüştür


109

bende bir tane var String[]

String[] name = {"amit", "rahul", "surya"};

IN yan tümcesinde sql sorgusunda parametre olarak adı göndermek istiyorum, bu yüzden bir formata nasıl dönüştürebilirim

'amit','rahul','surya'

18
Peki yaString[] name = {"O'Neill"};
Bart Kiers

Yanıtlar:


31
if (name.length > 0) {
    StringBuilder nameBuilder = new StringBuilder();

    for (String n : name) {
        nameBuilder.append("'").append(n.replace("'", "\\'")).append("',");
        // can also do the following
        // nameBuilder.append("'").append(n.replace("'", "''")).append("',");
    }

    nameBuilder.deleteCharAt(nameBuilder.length() - 1);

    return nameBuilder.toString();
} else {
    return "";
}

10
O zaman bir sürü çek yazardım. Sadece kavramı açıklıyorum, hepsini kurtarmaya örnek vermiyorum.
Nico Huysamen

3
Tekrar, kavramlar ... Ve olumsuz oy için teşekkürler. Ama işte gidiyorsun, düzelttin.
Nico Huysamen

teşekkürler benim gün tasarrufu sizi dostum ama ben bu durumun alabilirsiniz çünkü aynı zamanda @Bart Kiers cevabını verebilir değil zihin yapmak ve eğer ben plz programlama için yeni
Deepak Kumar

7
Ohhh, neden birçok kaynak hatları sadece kullanabilirsiniz eğer öyleyse yazma ihtiyacı var String.join(...)ya TextUtils.join(...)?
Eugene Brusov

2
@EugeneBrusov Gidip tahmin edeceğim çünkü cevabım 2011'de Java 8'in yayınlanmasından çok önce yayınlandı;)
Nico Huysamen

211

Ya kendiniz basit bir yöntem yazın ya da oradaki çeşitli yardımcı programlardan birini kullanın.

Ben şahsen apache StringUtils ( StringUtils.join ) kullanıyorum

düzenleme: Java 8'de artık buna ihtiyacınız yok:

String joined = String.join(",", name);

3
Kesinlikle! Hatta kendi sınırlayıcılarınızı bile tanımlayabilirsiniz:StringUtils.join(names,',');
delilik

5
String list = "'" + StringUtils.join(names,"','") + "'";bu size SQL isteğinin ihtiyaç duyduğu Tek tırnakları verecektir.
haysclark

Android için:TextUtils.join(",", stringArrayOfEmails)
Pratik Butani



47
StringBuilder sb = new StringBuilder();
for (String n : name) { 
    if (sb.length() > 0) sb.append(',');
    sb.append("'").append(n).append("'");
}
return sb.toString();

1
@Bmoeller denedin TextUtils.join(...)mi? Sanırım bir satır kodu, beş satırdan daha iyi ve daha basit.
Eugene Brusov

27

org.apache.commons.lang.StringUtilsJava'da dize dizisinden virgülle ayrılmış bir sonuç oluşturmak için API'yi de kullanabilirsiniz .

StringUtils.join(strArr,",");


9

Bağımlılık olarak Spring Framework'e zaten sahipseniz, çok basit kullanım yöntemini de kullanabilirsiniz:

org.springframework.util.StringUtils.arrayToCommaDelimitedString(String[] array)

7

Guava kütüphanesini kullanarak da basitleştirebilirsiniz:

String[] name = {"amit", "rahul", "surya"};
String str = "'" + Joiner.on(",").skipNulls().join(name)
    .replace(",", "','") + "'";

Çıktı nerede nasıl Guava kitaplığını kullanırım: "amit,rahul,surya"?
Compaq LE2202x

5

Kullanım StringBuilderbunun içine dize [] ve ekleme her dize üzerinde ve tekrarlayın:

public static String convert(String[] name) { 
    StringBuilder sb = new StringBuilder();
    for (String st : name) { 
        sb.append('\'').append(st).append('\'').append(',');
    }
    if (name.length != 0) sb.deleteCharAt(sb.length()-1);
    return sb.toString();
}

4

Bunu bir satır kodla yapabilirsiniz:

Arrays.toString(strings).replaceAll("[\\[.\\].\\s+]", "");

3
String[] name = {"amit", "rahul", "surya"};


public static String arrayToString(String array[])
{
    if (array.length == 0) return "";
    StringBuilder sb = new StringBuilder();
    for (int i = 0; i < array.length; ++i)
    {
        sb.append(",'").append(array[i]).append("'");
    }
    return sb.substring(1);
}

2
Muhtemelen demek istedin substring(1), ama ya eğer array.length == 0?
Bart Kiers

2

Bunu kullanıyorum

public static String convertToCommaSeparated(String[] strings) {
    StringBuffer sb = new StringBuffer("");
    for (int i = 0; strings != null && i < strings.length; i++) {
        sb.append(strings[i]);
        if (i < strings.length - 1) {
            sb.append(',');
        }
    }
    return sb.toString();
}

1

KULLANIM StringUtils.joinişlevi: Ör.

String myCsvString = StringUtils.join(myList, ",")

1
Neden daha önce birden çok kez gönderilen bir yanıt gönderilsin?
Charles Goodwin

1
String[] paramIdIdList={"P001","P002","P003"};

StringBuilder builder = new StringBuilder();
            for(String paramId : paramIdIdList) {
                builder.append(paramId+",");
            }
            builder.deleteCharAt(builder.length() -1);
            String paramIds = builder.toString();
System.Out.Println(paramIds );

Lütfen kodunuzun tam olarak ne yaptığına ilişkin bir açıklama ekleyin.
Hille

[] Dizesini virgülle ayrılmış dizeye dönüştürme
Vinayak

Cevabınızda, çünkü doğru bir kod olduğunu bilir. Ne daha fazla ne de eksik, ama yardımı yok.
Hille

1

Kodu olarak cazip ve "cool" görünebilir gibi, kullanmayın foldveyareduce bunlardan yaşayacaktır olarak, dizeleri büyük koleksiyonları üzerinde dize birleştirme sorunu

String[] strings = { "foo", "bar", "baz" };
Optional<String> result = Arrays.stream(strings)
        .reduce((a, b) -> String.format("%s,%s", a, b));
System.out.println(result.get());

Bunun yerine, diğer yanıtlarda olduğu gibi, String.join()zaten bir koleksiyonunuz StringBuildervarsa veya yoksa a kullanın.


0
String newNameList=null;

 for(int i = name.length;i>=0;i--){
    if(newNameList==null){
        newNameList = "\'" + name[name.length - i] + "\'";
    }
    else{
        newNameList += ",\'" + name[name.length - i] + "\'";
    }
}

0

Ayrıca bu kadar basit bir işlem için StringBuilder'ı spawnlamamak isteyebilirsiniz. Ben adresinin dizinin adını değiştirdik unutmayınız isim için isimlerin içerik uygunluk uğruna:

String[] names = {"amit", "rahul", "surya"};

String namesString = "";
int delimeters = (names.size() - 1);
for (String name : names)
    namesString += (delimeters-- > 0) ? "'" + name + "'," : "'" + name + "'";

0

For () döngüsünü dikey olarak aralıklandırmayı pek umursamıyorsanız, iki satır (bildirimler hariç; 'finalstring' başlangıçta boş bir dizeye eşit olarak bildirilmelidir):

for (int i = 0; i<string_array.length; i++) {finalstring += string_array[i]+",";}
finalstring = finalstring.substring(0,finalstring.length()-1);

İki satır, bitirdiniz. :)


0

burada bir diziyi bölmek ve özel sınırlayıcınızı koymak için bir Yardımcı Program yöntemi verilmiştir.

String.replace(String,String)
Arrays.toString(Object[])

işte burada :

public static String toString(String delimiter, Object[]array){
    String s = "";

    // split array
    if (array != null && array.length > 0) {
        s = Arrays.toString(array).replace("[", "").replace("]", "");
    }

    // place delimiter (notice the space in ", ")
    if(delimiter != null){
        s = s.replace(", ", delimiter);
    }

    return s;
}

ikinci bağımsız değişken türünü dizi türünüze uyacak şekilde değiştirin


0

Bu, bunu yapmanın optimize edilmiş bir yolu olacaktır

StringBuilder sb = new StringBuilder();
for (String n : arr) { 
    sb.append("'").append(n).append("',");
}
if(sb.length()>0)
    sb.setLength(sbDiscrep.length()-1);
return sb.toString();

0

Önceki Java 8 çözümü için uzantı

String result = String.join(",", name);

Dizi değerleri için öneke ve / veya son eke ihtiyacınız varsa

 StringJoiner joiner = new StringJoiner(",");
 for (CharSequence cs: name) {
     joiner.add("'" + cs + "'");
 }
 return joiner.toString();

Veya basit yöntem kavramı

  public static String genInValues(String delimiter, String prefix, String suffix, String[] name) {
    StringJoiner joiner = new StringJoiner(delimiter);
    for (CharSequence cs: name) {
      joiner.add(prefix + cs + suffix);
    }
    return joiner.toString();
  }

Örneğin

For Oracle i need "id in (1,2,3,4,5)" 
then use genInValues(",", "", "", name);
But for Postgres i need "id in (values (1),(2),(3),(4),(5))"
then use genInValues(",", "(", ")", name);

-1

Bu benim yardımcı olacağım !!!

private static String convertArrayToString(String [] strArray) {
            StringBuilder builder = new StringBuilder();
            for(int i = 0; i<= strArray.length-1; i++) {
                if(i == strArray.length-1) {
                    builder.append("'"+strArray[i]+"'");
                }else {
                    builder.append("'"+strArray[i]+"'"+",");
                }
            }
            return builder.toString();
        }

3
Lütfen cevabınıza biraz bağlam sağlayın.
Matthieu Brucher
Sitemizi kullandığınızda şunları okuyup anladığınızı kabul etmiş olursunuz: Çerez Politikası ve Gizlilik Politikası.
Licensed under cc by-sa 3.0 with attribution required.