我需要从文件(.csv)中读取值,该文件同时包含正值和负值。在将字符串转换为整数时出现错误。
Scanner sc = new Scanner(getAssets().open("Book1.csv")).useDelimiter(",");
int i = 0;
while (sc.hasNext()) {
String str = sc.next();
data[i] = new GraphViewData(i, Integer.parseInt(str));
i++;
}
下面是我的logcat:
05-02 04:05:55.119: E/AndroidRuntime(3003): ' as integer
05-02 04:05:55.119: E/AndroidRuntime(3003): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1647)
05-02 04:05:55.119: E/AndroidRuntime(3003): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663)
05-02 04:05:55.119: E/AndroidRuntime(3003): at android.app.ActivityThread.access$1500(ActivityThread.java:117)
05-02 04:05:55.119: E/AndroidRuntime(3003): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931)
05-02 04:05:55.119: E/AndroidRuntime(3003): at android.os.Handler.dispatchMessage(Handler.java:99)
05-02 04:05:55.119: E/AndroidRuntime(3003): at android.os.Looper.loop(Looper.java:123)
05-02 04:05:55.119: E/AndroidRuntime(3003): at android.app.ActivityThread.main(ActivityThread.java:3683)
05-02 04:05:55.119: E/AndroidRuntime(3003): at java.lang.reflect.Method.invokeNative(Native Method)
05-02 04:05:55.119: E/AndroidRuntime(3003): at java.lang.reflect.Method.invoke(Method.java:507)
05-02 04:05:55.119: E/AndroidRuntime(3003): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
05-02 04:05:55.119: E/AndroidRuntime(3003): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
05-02 04:05:55.119: E/AndroidRuntime(3003): at dalvik.system.NativeStart.main(Native Method)
05-02 04:05:55.119: E/AndroidRuntime(3003): Caused by: java.lang.NumberFormatException: unable to parse '893
5条答案
按热度按时间aemubtdh1#
要将字符串中的负值转换为整数,可以使用Integer.parseInt,如代码中所示。
我不认为您看到的错误与减号有关-传递以ASCII减号开头的字符串是可以的(请参阅http://docs.oracle.com/javase/1.4.2/docs/api/java/lang/Integer.html#parseInt(java.lang.String))
顺便说一句-你想转换成整数还是双精度?你的问题标题提到了双精度(双精度。parseDouble也接受符号)
pgx2nnw82#
你可以像这样
vhmi4jdf3#
Integer.parseInt
应该适用于负数。但是,请注意,您可以将负数写成- 3
,而不只是-3
。多余的空格将导致解析失败。您需要确保您实际尝试解析的是没有任何其他字符串的实际数字。您可以使用诸如so
Integer.parseInt(str.replaceAll("[^\\d-]+", ""));
之类的语句来删除所有非数字数据。编辑:根据您的异常,您的字符串中似乎有一个额外的 `,这导致转换失败。请确保在尝试将字符串解析为数字时只有数字。
drkbr07n4#
你可以用这个
brjng4g35#
从您的csv文件导入的减号是另一个ASCII码。一个简单快捷的方法是: