OpenCSV - 将List <string []>转换为List <integer>列表?

时间:2015-08-11 12:19:24

标签: java rest csv export-to-csv opencsv

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

我正在创建一个程序,我需要一些将CSV转换为int的方法,所以我可以总结一下。

@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

@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

<?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> 

也许还有更好的方法可以解决这个问题?我每次执行GET时都会实施CSV作为维护数据的方法。

3 个答案:

答案 0 :(得分:0)

直接使用java8 stream API总和:

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

答案 1 :(得分:0)

public static int sum(List<String[]> source, int totalSum)
{
    for(String[] arr: source)
    {
        for(String s: arr) totalSum += Integer.valueOf(s);
    }
}

答案 2 :(得分:0)

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

String[] entries = valueString.split(",");
long sum = 0;

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

我使用long而不是int,因为有时会发生整数字段的总和超过整数类型限制。因此,需要多长时间才能获得更安全的一面。

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

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