我正在研究 Android 中的 Rating Bar,其中 Rating 的值是从 Web 服务中获取的。我得到的数据是这样的 xml 形式。
5.0
在获取时,我正在解析 xml 并获取字符串中的所有值。现在我正在将 String 的值转换为 Float 以进行评级,但当时我得到了 NumberFormatException。我不知道为什么,我已经将其他数据从 String 解析为 Double 但当时我没有收到任何错误但是当尝试从 String 转换为 Float 我不知道为什么它会抛出异常......
这是我的示例代码。
ArrayList<HashMap<String, Object>> mylist = new ArrayList<HashMap<String, Object>>();
try {
//Get the xml string from the server
xml = XMLFunctions.getXML(url);
doc = XMLFunctions.XMLfromString(xml);
nodes = doc.getElementsByTagName("result");
for (int i = 0; i < nodes.getLength(); i++) {
HashMap<String, Object> map = new HashMap<String, Object>();
Element e = (Element)nodes.item(i);
map.put(Constants.NAME, XMLFunctions.getValue(e, "name"));
System.out.println("Rating = " + XMLFunctions.getValue(e, "rating"));
map.put(Constants.RATING, (Float.parseFloat(XMLFunctions.getValue(e, "rating"))));
mylist.add(map);
}
另一个尝试:-
String ratingValue = XMLFunctions.getValue(e, "rating");
System.out.println(ratingValue);// it gives me 5.0
float myRating = 0.0f;
myRating = Float.parseFloat(ratingValue); // getting exception here
System.out.println("Rating = **" + myRating + "**");//it gives me Rating = **5.0**
错误日志:-
04-01 08:44:59.986: I/System.out(382): Rating = 5.0
04-01 08:45:00.056: W/System.err(382): java.lang.NumberFormatException:
04-01 08:45:00.056: W/System.err(382): at org.apache.harmony.luni.util.FloatingPointParser.parseFloat(FloatingPointParser.java:305)
04-01 08:45:00.065: W/System.err(382): at java.lang.Float.parseFloat(Float.java:323)
04-01 08:45:00.065: W/System.err(382): at place.locator.PlaceLocatorActivity$ParseXMLData.doInBackground(PlaceLocatorActivity.java:173)
04-01 08:45:00.065: W/System.err(382): at place.locator.PlaceLocatorActivity$ParseXMLData.doInBackground(PlaceLocatorActivity.java:1)
04-01 08:45:00.065: W/System.err(382): at android.os.AsyncTask$2.call(AsyncTask.java:185)
04-01 08:45:00.065: W/System.err(382): at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:306)
04-01 08:45:00.065: W/System.err(382): at java.util.concurrent.FutureTask.run(FutureTask.java:138)
04-01 08:45:00.065: W/System.err(382): at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1088)
04-01 08:45:00.065: W/System.err(382): at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:581)
04-01 08:45:00.065: W/System.err(382): at java.lang.Thread.run(Thread.java:1019)
我不知道我在哪里犯错。如果有人能发现它,请告诉我。我知道这一定是一些愚蠢的错误,但有些人无法发现它。
谢谢