当前位置:  开发笔记 > 编程语言 > 正文

从Collection/Array/List创建以逗号分隔的字符串的最复杂方法?

如何解决《从Collection/Array/List创建以逗号分隔的字符串的最复杂方法?》经验,为你挑选了10个好方法。

在我使用数据库的过程中,我注意到我编写了查询字符串,在这个字符串中,我必须在list/array/collection的where子句中加入一些限制.应该是这样的:

select * from customer 
where customer.id in (34, 26, ..., 2);

您可以通过将此问题简化为具有字符串集合的问题并希望仅在一个字符串中创建此字符串的逗号分隔列表来简化此操作.

我到目前为止使用的方法是这样的:

String result = "";
boolean first = true;
for(String string : collectionOfStrings) {
    if(first) {
        result+=string;
        first=false;
    } else {
        result+=","+string;
    }
}

但这是你可以看到非常丑陋的.您无法看到第一眼看到的情况,特别是当构造的字符串(如每个SQL查询)变得复杂时.

你(更)优雅的方式是什么?



1> Julie..:

使用Google Guava API的join方法:

Joiner.on(",").join(collectionOfStrings);


同时,org.apache.commons.lang.StringUtils保持不变.:-)
如今这个班叫做"Joiner"; http://google-collections.googlecode.com/svn/trunk/javadoc/com/google/common/base/Joiner.html
今天,Collections已被弃用.请改用[Google Guava](http://code.google.com/p/guava-libraries/).

2> gimel..:

由于字符串是不可变的,因此如果您要更改代码中的String,则可能需要使用StringBuilder类.

StringBuilder类可以看作是一个可变的String对象,它在更改内容时分配更多的内存.

通过处理冗余的尾随逗号,可以更清楚有效地编写问题中的原始建议:

    StringBuilder result = new StringBuilder();
    for(String string : collectionOfStrings) {
        result.append(string);
        result.append(",");
    }
    return result.length() > 0 ? result.substring(0, result.length() - 1): "";


请注意,这要求您的集合至少包含一个元素.
我希望java会添加一个原生的一个衬垫来做这个.
请参阅最高投票回答 - http://code.google.com/p/guava-libraries/wiki/StringsExplained

3> Ogre Psalm33..:

我刚看了今天这样做的代码.这是AviewAnew答案的变体.

collectionOfStrings = /* source string collection */;
String csList = StringUtils.join(collectionOfStrings.toArray(), ",");

我们使用的StringUtils(< - commons.lang 2.x或commons.lang 3.x链接)来自Apache Commons.


很好,谢谢.StringUtils #joed也适用于Iterable,因此可能不需要先将集合转换为数组.

4> Tom Hawtin -..:

我写这个循环的方式是:

StringBuilder buff = new StringBuilder();
String sep = "";
for (String str : strs) {
    buff.append(sep);
    buff.append(str);
    sep = ",";
}
return buff.toString();

不要担心sep的性能.作业非常快.无论如何,Hotspot倾向于剥离循环的第一次迭代(因为它经常需要处理诸如null和单/双态内联检查之类的奇怪现象).

如果您使用它(不止一次),请将其放在共享方法中.

stackoverflow还有另一个问题,涉及如何将一个id列表插入到SQL语句中.



5> Abdull..:

从Java 8开始,您可以使用:

String String.join(CharSequence delimiter, CharSequence... elements)

String String.join(CharSequence delimiter, Iterable elements)

如果你想取非Strings并将它们加入a String,你可以使用Collectors.joining(CharSequence delimiter),例如:

String joined = anyCollection.stream().map(Object::toString).collect(Collectors.joining(","));


这很好!如果您正在操作需要toString()未涵盖的特殊字符串转换的对象,请将Object :: toString替换为将您的类映射到String的java.util.function.Function .
此外,您可以像这样使用它:`cats.stream().map(cat - > cat.getName()).collect(Collectors.joining(","));`来自您的集合中的单个变量.

6> Miguel Ping..:

我发现iterator成语优雅,因为它有更多元素的测试(ommited null/empty test为简洁起见):

public static String convert(List list) {
    String res = "";
    for (Iterator iterator = list.iterator(); iterator.hasNext();) {
        res += iterator.next() + (iterator.hasNext() ? "," : "");
    }
    return res;
}



7> case nelson..:

有很多手动解决方案,但我想重申和更新上面的Julie的答案.使用谷歌收藏品Joiner课程.

Joiner.on(", ").join(34, 26, ..., 2)

它处理var args,iterables和数组,并正确处理多个char的分隔符(与gimmel的答案不同).如果需要,它还将处理列表中的空值.



8> 小智..:

这是一个令人难以置信的通用版本,我是根据以前的建议组合而成的:

public static  String buildCommaSeparatedString(Collection values) {
    if (values==null || values.isEmpty()) return "";
    StringBuilder result = new StringBuilder();
    for (T val : values) {
        result.append(val);
        result.append(",");
    }
    return result.substring(0, result.length() - 1);
}



9> robjwilkins..:
String.join(", ", collectionOfStrings)

可以在Java8 api中找到.

替代(不需要添加谷歌番石榴依赖):

Joiner.on(",").join(collectionOfStrings);



10> Peter Lawrey..:

你可以试试

List collections = Arrays.asList(34, 26, "...", 2);
String asString = collection.toString();
// justValues = "34, 26, ..., 2"
String justValues = asString.substring(1, asString.length()-1);

推荐阅读
郑小蒜9299_941611_G
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有