OpenCSV - 将列表<字符串[]>转换为列表<Integer>列表?



是否可以将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作为维护数据的一种方式来实现。

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

直接使用java8流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));
}

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

String[] entries = valueString.split(",");
long sum = 0;
for(String entry : entries)
{
    sum += Long.parseLong(entry.trim());
}

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

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

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

相关内容

  • 没有找到相关文章

最新更新