从CSV文件读取NULL值

时间:2018-08-23 16:36:08

标签: java android csv google-maps-markers

我的应用程序遇到两个问题。第一个是我试图从具有空值的CSV文件中读取一列。第二个是基于从CSV读取的值,我应该更改在google地图上上传的标记的颜色,但是现在颜色根据上一次读取的值而更改,并且所有标记都具有相同的颜色,而不是颜色基于它们的对应值。所以我的问题是:当应用程序从CSV转换为空值时,如何阻止该应用程序崩溃,我是否要根据其对应的值更改每个标记的颜色?

CSV文件:

1,45.66680458,25.60458787,salvat
2,45.66672655,25.6047773,gresit
3,45.66670734,25.60465392,

更新的工作代码:

 public void Upload() throws IOException {

    File file = new File(getExternalFilesDir(null), "fisier.csv");
    if (file.exists()) {
        InputStream instream = new FileInputStream(file);
        InputStreamReader inputreader = new InputStreamReader(instream);
        BufferedReader reader = new BufferedReader(inputreader);
        List<LatLng> latLngList = new ArrayList<LatLng>();
        String line = " ";
        List<String> stares = new ArrayList<String>();
        while ((line = reader.readLine()) != null) // Read until end of file
        {
            String[] tokens = line.split(",", 4);
            double lat = Double.parseDouble(tokens[1]);
            double lon = Double.parseDouble(tokens[2]);
            stare = String.valueOf(tokens[3]);

            latLngList.add(new LatLng(lat, lon));
            stares.add(stare);
            mMap.setOnMarkerClickListener(this);




    }
        reader.close();
        for (int i = 0; i < latLngList.size(); i++) {
            float color = 0;

            if (stares.get(i).equals("gresit")) {
                color = BitmapDescriptorFactory.HUE_BLUE;
            }
            else if (stares.get(i).equals("salvat")) {
                color = BitmapDescriptorFactory.HUE_GREEN;
            }
            else {
                color = BitmapDescriptorFactory.HUE_RED;
            }
            mMap.addMarker(new MarkerOptions()
                    .position(latLngList.get(i))
                    .title("Din CSV!")
                    .draggable(true)
                    .icon(BitmapDescriptorFactory.defaultMarker(color)));

                mMap.animateCamera(CameraUpdateFactory.newLatLngZoom(latLngList.get(i), DEFAULT_ZOOM));

    }

        Toast.makeText(MapsActivity.this,"Fisierul a fost incarcat", Toast.LENGTH_SHORT).show();
        }


    else
    {
        Toast.makeText(MapsActivity.this,"Nu exista fisierul!", Toast.LENGTH_SHORT).show();
    }

}

1 个答案:

答案 0 :(得分:1)

stare值定义另一个列表:
List<String> stares = new ArrayList<String>();
latLngList.add(new LatLng(lat, lon));之后的while循环内添加以下内容:
stares.add(stare);

更改for循环:

    for (int i = 0; i < latLngList.size(); i++) {
        if (stares.get(i).equals("gresit")) {
            color = BitmapDescriptorFactory.HUE_BLUE;
        } else if (stares.get(i).equals("salvat")) {
            color = BitmapDescriptorFactory.HUE_GREEN;
        } else {
            color = BitmapDescriptorFactory.HUE_RED;
        }
        mMap.addMarker(new MarkerOptions()
                .position(latLngList.get(i))
                .title("Din CSV!")
                .draggable(true)
                .icon(BitmapDescriptorFactory.defaultMarker(color))

    };

更新:
stare = String.valueOf(tokens[3]);替换为:

try {
    stare = String.valueOf(tokens[3]);
} catch (Exception e) {
    stare = "";
    e.printStackTrace();
}

因此,如果没有第四列,则应用程序不会崩溃。