首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >ClassNotFoundException geosparksql.UDT.GeometryUDT

ClassNotFoundException geosparksql.UDT.GeometryUDT
EN

Stack Overflow用户
提问于 2020-06-15 10:08:54
回答 1查看 573关注 0票数 0

我一直试图将GeoPandas数据格式转换为PySpark数据格式,但没有成功。目前,我已经扩展了DataFrame类,将GPD DF转换为Spark,如下所示:

代码语言:javascript
复制
from pyspark.sql import DataFrame
from pyspark.sql.types import IntegerType, StringType, FloatType, BooleanType, DateType, TimestampType, StructField, StructType
!pip install geospark
from geospark.sql.types import GeometryType

class SPandas(DataFrame):
  def __init__(self, sqlC, objgpd):
    esquema = dict(objgpd.dtypes)
    equivalencias = {'int64' : IntegerType, 'object' : StringType, 'float64' : FloatType, 
                     'bool' : BooleanType, 'datetime64' : DateType,
                     'timedelta' : TimestampType, 'geometry' : GeometryType}

    for clave, valor in esquema.items():
      try:
        esquema[clave] = equivalencias[str(valor)]
      except KeyError:
        esquema[clave] = StringType

    esquema = StructType([ StructField(v, esquema[v](), False) for v in esquema.keys() ])
    datos = sqlC.createDataFrame(objgpd, schema=esquema)
    super(self.__class__, self).__init__(datos._jdf, datos.sql_ctx)

前面的代码编译时没有出错,但是当试图从DataFrame‘获取’一个项时,我会得到以下错误:

代码语言:javascript
复制
fp = "Paralela/Barrios/Barrios.shp"
map_df = gpd.read_file(fp)
mapa_sp = SPandas(sqlC, map_df)
mapa_sp.take(1)

Py4JJavaError: An error occurred while calling o21.applySchemaToPythonRDD.
: java.lang.ClassNotFoundException: org.apache.spark.sql.geosparksql.UDT.GeometryUDT

问题在于GDP DF的“几何学”列,因为没有它,它的工作是完美无缺的。“几何图形”列有形状优美的多边形对象,应该由GeometryType类GeoSpark识别。

有没有办法安装org.apache.spark.sql.geosparksql.UDT.GeometryUDT??我在用Google Colab。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-06-15 10:29:23

您需要在hour项目中包含geospark依赖项,并将jar添加到您的运行时env。类路径。下面的jar版本与spark-core_2.11:2.3.0兼容

代码语言:javascript
复制
<dependency>
    <groupId>org.datasyslab</groupId>
    <artifactId>geospark</artifactId>
    <version>1.3.1</version>
    <scope>provided</scope>
</dependency>
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/62385942

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档