【Spark】根据经纬度算出对应的城市

本文介绍了一种基于Spark的算法,通过创建城市经纬度地图,实现全国范围内的精确地理位置匹配,以便快速确定电话位置报告中坐标所对应的城市代码。作者分享了从ODS数据集中提取城市边界信息并利用自定义函数进行查找的过程。
摘要由CSDN通过智能技术生成

思路:造一个存有全国每个城市边界经纬度的信息表,把经纬度点使用算法公式按照一定的逻辑挨个循环去匹配。

处理过程中的城市经纬度Map类似于如下:

如果要全国的可以访问如下链接下载相对应的csv

https://download.csdn.net/download/Aaron_ch/16165798

全部实现逻辑代码如下:

import org.apache.spark.SparkConf;
import org.apache.spark.sql.Dataset;
import org.apache.spark.sql.Row;
import org.apache.spark.sql.SparkSession;
import org.apache.spark.sql.api.java.UDF2;
import org.apache.spark.sql.types.DataTypes;

import java.util.HashMap;
import java.util.List;
import java.util.Map;

/**
 * @Author: aaron
 * @Date: 2021/3/8 18:11
 * @Description:
 */
public class JustDoIt {

    static boolean isInLongLat(double ALon, double ALat, double[][] APoints) {
        boolean bRet = false;
        int iSu
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值