Converter String [] em string separada por vírgulas em java

109

eu tenho um String[]

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

Eu quero enviar o nome como parâmetro na consulta sql dentro da cláusula IN, então como faço para converter em um formato

'amit','rahul','surya'
Deepak Kumar
fonte
18
E sobreString[] name = {"O'Neill"};
Bart Kiers

Respostas:

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 "";
}
Nico Huysamen
fonte
10
Então eu teria escrito um monte de cheques. Estou apenas explicando o conceito, não dando o exemplo de salvar tudo.
Nico Huysamen
3
Novamente, conceitos ... E obrigado pelo voto negativo. Mas aí está, consertou.
Nico Huysamen
obrigado amigo você salva meu dia, mas se você não se importa, você também pode dar a resposta de @Bart Kiers porque eu posso entender essa situação e eu sou novo em programação plz
Deepak Kumar
7
Ohhh, por que é necessário escrever tantas linhas de origem se você pode simplesmente usar String.join(...)ou TextUtils.join(...)?
Eugene Brusov
2
@EugeneBrusov Vou tentar adivinhar porque a resposta postada em 2011 muito antes do lançamento do Java 8;)
Nico Huysamen
211

Escreva um método simples você mesmo ou use um dos vários utilitários por aí.

Pessoalmente, eu uso o apache StringUtils ( StringUtils.join )

editar: no Java 8, você não precisa mais disso:

String joined = String.join(",", name);
Joeri Hendrickx
fonte
3
Exatamente! Você pode até definir seus próprios delimitadores:StringUtils.join(names,',');
insanidade
5
String list = "'" + StringUtils.join(names,"','") + "'";isso forneceria as aspas simples necessárias para a solicitação SQL.
haysclark
Para Android:TextUtils.join(",", stringArrayOfEmails)
Pratik Butani
51

Bom e simples: mas requer java8!

String result = String.join(",", names);
Christopher Perry
fonte
47
StringBuilder sb = new StringBuilder();
for (String n : name) { 
    if (sb.length() > 0) sb.append(',');
    sb.append("'").append(n).append("'");
}
return sb.toString();
NPE
fonte
1
@Bmoeller Você já tentou TextUtils.join(...)? Acho que um código de linha é ainda melhor e mais simples do que cinco.
Eugene Brusov
27

Você também pode usar a org.apache.commons.lang.StringUtilsAPI para formar um resultado separado por vírgula da matriz de string em Java.

StringUtils.join(strArr,",");

user797649
fonte
9

Se você já tem Spring Framework como dependência, também pode usar o método util muito simples:

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

Você também pode simplificar usando a biblioteca Guava:

String[] name = {"amit", "rahul", "surya"};
String str = "'" + Joiner.on(",").skipNulls().join(name)
    .replace(",", "','") + "'";
acvcu
fonte
Como faço para usar a biblioteca Guava onde a saída é "amit,rahul,surya":?
Compaq LE2202x
5

use StringBuildere itere sobre sua String [] e anexe cada String nela:

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();
}
amit
fonte
4

Você pode fazer isso com uma linha de código:

Arrays.toString(strings).replaceAll("[\\[.\\].\\s+]", "");
nullbyte
fonte
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);
}
Martijn Courteaux
fonte
2
Você provavelmente quis dizer substring(1), mas e se array.length == 0?
Bart Kiers
2

Eu uso isso

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();
}
Sodiq
fonte
1

StringUtils.joinFunção USE : Ex.

String myCsvString = StringUtils.join(myList, ",")
Manu
fonte
1
Por que postar uma resposta que já foi postada várias vezes?
Charles Goodwin de
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 );
Vinayak
fonte
Adicione uma descrição do que seu código está fazendo exatamente.
Hille
Convertendo String [] em string separada por vírgulas
Vinayak
Em sua resposta, porque certo sabe que existe algum código. Nada mais e nada menos, mas não ajuda.
Hille
1

Por mais tentador e "legal" que o código possa parecer, não use foldoureduce em grandes coleções de strings, pois estas sofrerão com o problema de concatenação de strings

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());

Em vez disso, como para outras respostas, use String.join()se você já tiver uma coleção, ou StringBuilderse não tiver.

StuartLC
fonte
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] + "\'";
    }
}
Logan
fonte
0

Você também pode querer não gerar StringBuilder para uma operação tão simples. Observe que alterei o nome da sua matriz de nome para nomes por uma questão de conformidade do conteúdo:

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

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

Duas linhas (excluindo as declarações; 'finalstring' deve ser inicialmente declarada igual a uma string vazia), se você não se importar muito com o espaçamento vertical do loop for ():

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

Duas linhas, está feito. :)

Matt Campbell
fonte
0

aqui está um método utilitário para dividir uma matriz e colocar seu delimitador personalizado, usando

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

Aqui está :

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;
}

mude o segundo tipo de argumento para se adequar ao seu tipo de array

Ahmed Adel Ismail
fonte
0

Esta seria uma maneira otimizada de fazer isso

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();
Riz
fonte
0

Extensão para solução anterior Java 8

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

Se você precisar de um prefixo ou / e sufixo para valores de matriz

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

Ou conceito de método simples

  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();
  }

Por exemplo

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);
Volátil
fonte
-1

Isso pode ser útil !!!

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();
        }
Jyoti Prakash
fonte
3
Forneça algum contexto para sua resposta.
Matthieu Brucher