Java Integer.parseInt()对UTF-8文件抛出NumberFormatException
我需要解析文件内容中的整数 为了测试我的算法,当我从声明的字符串中给出文件的内容时Java Integer.parseInt()对UTF-8文件抛出NumberFormatException,java,integer,java.util.scanner,Java,Integer,Java.util.scanner,我需要解析文件内容中的整数 为了测试我的算法,当我从声明的字符串中给出文件的内容时 String test = "15 kuruş"; Integer.parseInt工作正常。但是当我从UTF-8文件中读取Scanner类时,它不起作用,并给出了异常 java.lang.NumberFormatException:用于输入字符串:“15” 注意:我将字符串拆分为“15”和“kuruş”,因此parseInt方法只接受“15”作为参数 示例代码: satir = satir.trim(
String test = "15 kuruş";
Integer.parseInt工作正常。但是当我从UTF-8文件中读取Scanner类时,它不起作用,并给出了异常
java.lang.NumberFormatException:用于输入字符串:“15”
注意:我将字符串拆分为“15”和“kuruş”,因此parseInt方法只接受“15”作为参数
示例代码:
satir = satir.trim();//15 kuruş
StringTokenizer tokenizer = new StringTokenizer(satir," ");
System.out.println(tokenizer.countTokens());//2
String s = tokenizer.nextToken();
int deger = Integer.parseInt(s);//where the exception was throwed
您的UTF-8文件可能以a开头,您必须使用正确的编码读取该文件,或者手动将其删除
因此,当您的15不再使用BOM表时,
Integer.parseInt()
将起作用。请展示一个简短但完整的程序来演示问题。此外,请检查“1”和“5”是否为“普通”ASCII字符,或者是某个宽变量。如果按空格分割,BOM表可能在我编辑的15Ok之前。我猜这不是普通的ASCII字符。正如我在问题中指出的,当我给出一个测试字符串时,它工作正常,但当我从文件中读取相同的字符串时,它抛出异常that@NikolayKuznetsovBOM=“Byte Order Mark”可以出现在Unicode编码的文件中,以表示使用了哪种编码。有时会导致问题,因此经常被忽略。