激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - java 中Excel轉shape file的實例詳解

java 中Excel轉shape file的實例詳解

2020-12-30 11:35gisshixisheng Java教程

這篇文章主要介紹了java 中Excel轉shape file的實例詳解的相關資料,希望通過本文大家能實現這樣的功能,需要的朋友可以參考下

java  中excel轉shape file的實例詳解

概述:

本文講述如何結合geotools和poi實現excel到shp的轉換,再結合前文shp到geojson數據的轉換,即可實現用戶上傳excel數據并在web端的展示功能。

截圖:

java 中Excel轉shape file的實例詳解

 原始excel文件

java 中Excel轉shape file的實例詳解

運行耗時

java 中Excel轉shape file的實例詳解

運行結果

代碼:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
package com.lzugis.geotools;
 
import com.lzugis.commonmethod;
import com.vividsolutions.jts.geom.coordinate;
import com.vividsolutions.jts.geom.geometryfactory;
import com.vividsolutions.jts.geom.point;
import org.apache.poi.hssf.usermodel.hssfcell;
import org.apache.poi.hssf.usermodel.hssfrow;
import org.apache.poi.hssf.usermodel.hssfsheet;
import org.apache.poi.hssf.usermodel.hssfworkbook;
import org.apache.poi.poifs.filesystem.poifsfilesystem;
import org.geotools.data.featurewriter;
import org.geotools.data.transaction;
import org.geotools.data.shapefile.shapefiledatastore;
import org.geotools.data.shapefile.shapefiledatastorefactory;
import org.geotools.feature.simple.simplefeaturetypebuilder;
import org.geotools.referencing.crs.defaultgeographiccrs;
import org.opengis.feature.simple.simplefeature;
import org.opengis.feature.simple.simplefeaturetype;
 
import java.io.file;
import java.io.fileinputstream;
import java.io.inputstream;
import java.io.serializable;
import java.nio.charset.charset;
import java.util.arraylist;
import java.util.hashmap;
import java.util.list;
import java.util.map;
 
/**
 * created by admin on 2017/9/6.
 */
public class xls2shape {
  static xls2shape xls2shp = new xls2shape();
  private static string rootpath = system.getproperty("user.dir");
  private commonmethod cm = new commonmethod();
 
  private hssfsheet sheet;
 
  private class getcelltype(hssfcell cell) {
    if (cell.getcelltype() == hssfcell.cell_type_string) {
      return string.class;
    } else if (cell.getcelltype() == hssfcell.cell_type_numeric) {
      return double.class;
    } else {
      return string.class;
    }
  }
 
  private object getcellvalue(hssfcell cell) {
    if (cell.getcelltype() == hssfcell.cell_type_string) {
      return cell.getrichstringcellvalue().getstring();
    } else if (cell.getcelltype() == hssfcell.cell_type_numeric) {
      return cell.getnumericcellvalue();
    } else {
      return "";
    }
  }
 
  private list<map<string, object>> getexcelheader() {
    list<map<string, object>> list = new arraylist();
    hssfrow header = sheet.getrow(0);
    hssfrow value = sheet.getrow(1);
    //獲取總列數
    int colnum = header.getphysicalnumberofcells();
    for (int i = 0; i < colnum; i++) {
      hssfcell cellfield = header.getcell(i);
      hssfcell cellvalue = value.getcell(i);
      string fieldname = cellfield.getrichstringcellvalue().getstring();
      fieldname = cm.getpinyinheadchar(fieldname);
      class fieldtype = getcelltype(cellvalue);
      map<string, object> map = new hashmap<string, object>();
      map.put("name", fieldname);
      map.put("type", fieldtype);
      list.add(map);
    }
    return list;
  }
 
  public void excel2shape(string xlsfile, string shppath) {
    poifsfilesystem fs;
    hssfworkbook wb;
    hssfrow row;
    try {
      inputstream is = new fileinputstream(xlsfile);
      fs = new poifsfilesystem(is);
      wb = new hssfworkbook(fs);
      sheet = wb.getsheetat(0);
      //獲取總列數
      int colnum = sheet.getrow(0).getphysicalnumberofcells();
      // 得到總行數
      int rownum = sheet.getlastrownum();
 
      list list = getexcelheader();
      //創建shape文件對象
      file file = new file(shppath);
      map<string, serializable> params = new hashmap<string, serializable>();
      params.put(shapefiledatastorefactory.urlp.key, file.touri().tourl());
      shapefiledatastore ds = (shapefiledatastore) new shapefiledatastorefactory().createnewdatastore(params);
      //定義圖形信息和屬性信息
      simplefeaturetypebuilder tb = new simplefeaturetypebuilder();
      tb.setcrs(defaultgeographiccrs.wgs84);
      tb.setname("shapefile");
      tb.add("the_geom", point.class);
      for (int i = 0; i < list.size(); i++) {
        map<string, object> map = (map<string, object>) list.get(i);
        tb.add(map.get("name").tostring(), (class) map.get("type"));
      }
      ds.createschema(tb.buildfeaturetype());
      //設置編碼
      charset charset = charset.forname("gbk");
      ds.setcharset(charset);
      //設置writer
      featurewriter<simplefeaturetype, simplefeature> writer = ds.getfeaturewriter(ds.gettypenames()[0], transaction.auto_commit);
      //寫下一條
      simplefeature feature = null;
      for (int i = 1; i < rownum; i++) {
        row = sheet.getrow(i);
        feature = writer.next();
        map maplonlat = new hashmap();
        for (int j = 0; j < colnum; j++) {
          hssfcell cell = row.getcell(j);
          map<string, object> mapfields = (map<string, object>) list.get(j);
          string fieldname = mapfields.get("name").tostring();
          feature.setattribute(fieldname, getcellvalue(cell));
          if (fieldname.tolowercase().equals("lon") || fieldname.tolowercase().equals("lat")) {
            maplonlat.put(fieldname, getcellvalue(cell));
          }
        }
        feature.setattribute("the_geom", new geometryfactory().createpoint(new coordinate((double) maplonlat.get("lon"), (double) maplonlat.get("lat"))));
      }
      writer.write();
      writer.close();
      ds.dispose();
 
    } catch (exception e) {
      e.printstacktrace();
    }
  }
 
  public static void main(string[] args) {
    long start = system.currenttimemillis();
    string xlspath = rootpath + "/data/xls/capital.xls",
        shppath = rootpath + "/out/capital.shp";
    xls2shp.excel2shape(xlspath, shppath);
    system.out.println("共耗時" + (system.currenttimemillis() - start) + "ms");
  }
}

說明:

1、轉換僅限點對象的轉換;
2、保留所有excel相關的屬性,lon、lat字段是必須要有的;
3、對于中文字段,做了取首字母的處理;

 如有疑問請留言或者到本站社區交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

原文鏈接:http://blog.csdn.net/gisshixisheng/article/details/77877031

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 日韩欧美精品电影 | 中文字幕精品在线视频 | avlululu| 欧日一级片 | 国产精品一区二区视频 | 97人操| www.7777在线 | 免费一级欧美在线观看视频 | 欧美一级淫片007 | 精品一区二区在线播放 | 精品亚洲在线 | 日韩黄色精品 | 深夜毛片免费看 | 中文字幕在线观看亚洲 | 成人宗合网 | 欧美一级美国一级 | 国产男女爽爽爽爽爽免费视频 | 他也色在线视频 | 在线免费av网站 | 学霸趴下被打肿光屁股小说 | 国产一国产一级毛片视频 | www69xxxxx| 精品国产欧美一区二区 | 法国性xxx精品hd专区 | 久久精品日产第一区二区三区 | 日日爱夜夜操 | 成年性羞羞视频免费观看 | 免费一区二区三区 | 国产午夜精品一区二区三区不卡 | 蜜桃av鲁一鲁一鲁一鲁 | 国产成人精品一区二区视频免费 | 欧美精品一二三区 | 成人免费在线播放 | 久久99国产精品免费网站 | 在线观看一区二区三区四区 | 99这里精品| 天天干天天透 | 国产亚洲精彩视频 | 最新一区二区三区 | 羞羞的视频在线 | 国产精品一区在线观看 |