首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >OpenCSV - Convert List<String[]> to List<Integer> list?

OpenCSV - Convert List<String[]> to List<Integer> list?
EN

Stack Overflow用户
提问于 2015-08-11 20:19:24
回答 3查看 831关注 0票数 1

是否可以将List String[]转换为ListInteger list?

我正在创建一个程序,我需要一些将CSV转换为int的方法,这样我就可以对其求和。

代码语言:javascript
复制
@Path("/values")
public class values {

int totalSum = 0;
int value = 0;

List<Integer> list = new ArrayList<Integer>();

@GET
@Produces(MediaType.TEXT_PLAIN)
public int getSum() throws IOException {
    CSVReader reader = new CSVReader(new FileReader("yourfile.csv"));
    List<String[]> read = reader.readAll();
    //need to convert List<String[]> to List<Integer> list
    return sum.sum(list, totalSum);
}

@POST
public String addValue() throws IOException {
    String valueString = Integer.toString(value);
    CSVWriter writer = new CSVWriter(new FileWriter("yourfile.csv"), ',');
    String[] entries = valueString.split(",");
    writer.writeNext(entries);
    writer.close();
    return "ok";  
}  

@DELETE
@Produces(MediaType.TEXT_PLAIN)
public String deleteList() {
    list.clear();
    return "ok";
}

}

sum.java

代码语言:javascript
复制
@Path("/values/sum")
public class sum {

public static int sum(List<Integer> list, int totalSum) {
    for(int i : list) {
          totalSum += i;
          }
    return totalSum;
}

}

web.xml

代码语言:javascript
复制
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0">
  <display-name>PACKAGENAME</display-name>
 <servlet>
    <servlet-name>Jersey REST Service</servlet-name>
    <servlet-class>org.glassfish.jersey.servlet.ServletContainer</servlet-class>
     <!-- Register resources and providers under com.vogella.jersey.first package. -->
    <init-param>
        <param-name>jersey.config.server.provider.packages</param-name>
        <param-value>PACKAGENAME</param-value>
    </init-param>
    <load-on-startup>1</load-on-startup>
  </servlet>
  <servlet-mapping>
    <servlet-name>Jersey REST Service</servlet-name>
    <url-pattern>/api/*</url-pattern>
  </servlet-mapping>
</web-app> 

也许有更好的方法来解决这个问题呢?我实现CSV作为每次执行GET时维护数据的一种方式。

EN

回答 3

Stack Overflow用户

发布于 2015-08-11 20:22:23

直接使用java8流应用编程接口的总和:

代码语言:javascript
复制
private static int sum(List<String[]> stringArrayList){
    return stringArrayList.stream().flatMap(l -> Arrays.stream(l))
            .mapToInt(str -> Integer.valueOf(str)).sum();
}

public static void main(String args[]) {
    List<String[]> stringArrayList = Lists.newArrayListWithCapacity(2);
    String[] sArray1 = { "1", "5" };
    stringArrayList.add(sArray1);
    String[] sArray2 = { "53", "49" };
    stringArrayList.add(sArray2);

    System.out.println(sum(stringArrayList));
}
票数 0
EN

Stack Overflow用户

发布于 2015-08-11 20:30:01

代码语言:javascript
复制
public static int sum(List<String[]> source, int totalSum)
{
    for(String[] arr: source)
    {
        for(String s: arr) totalSum += Integer.valueOf(s);
    }
}
票数 0
EN

Stack Overflow用户

发布于 2015-08-11 20:42:40

你有数组的字符串,你可以通过迭代数组的每个元素将它解析成int:

代码语言:javascript
复制
String[] entries = valueString.split(",");
long sum = 0;

for(String entry : entries)
{
    sum += Long.parseLong(entry.trim());
}

我使用long而不是int,因为有时候整型字段的和会超过整型类型的限制。所以,花很长时间寻找更安全的一面。

不要忘记使用trim删除值中的空格,否则java将抛出NumberFormatException。

假设:字符串数组的所有元素都包含整数值,否则会抛出异常。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/31941617

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档