省市区三级联动查询redis(通过python脚本导入数据)

最近工作有一个工作需求是实现省市区联动,点击省下拉框,选中一个省,然后再选市,最后选区,当然最重要的首先自然是数据了,没数据怎么测试接口,我数据是在 https://hxkj.vip/demo/echartsMap/ 这里拿的,得到一个json文件,里面是一个list的结构,每一条数据都是省市区树级展示。

那么有数据之后,就要导入库中,之所以选用redis而不是mysql,是因为省市区数据是比较固定的,很难会有改动,所以放在redis反而更好

python脚本将json数据导入redis
复制代码
import redis
import json
r = redis.Redis(host='127.0.0.1', port=6379, db=4)
with open("C:\\Users\\10926\Desktop\\pca-code.json", 'r',encoding='utf-8-sig') as file:
    data = json.load(file)
for item in data:
 r.lpush('regionData', json.dumps(item))

只需要改个文件路径名即可

省市区联动下拉框展示

此时redis中的数据是这种格式,通过code来实现父子关联:

那么我们就可以通过code来实现省市区联动:

java 复制代码
	/**
	 *	没传code就是省,有就是市区
     * 分别查询省市区
     * @param regions
     * @param code
     * @return
     */
    public List<RegionVO> getRegionsByCode(List<RegionVO> regions, String code, RegionFlag flag) {
        List<RegionVO> result = new ArrayList<>();
        for (RegionVO region : regions) {
            // 不传code时查询所有省
            if (code == null) {
                result.add(new RegionVO(region.getCode(), region.getName(), null));
            } else if (region.getCode().equals(code)) {
                // 传入省或市的code时
                if (region.getChildren() != null) {
                    for (RegionVO child : region.getChildren()) {
                        result.add(new RegionVO(child.getCode(), child.getName(), null));
                    }
                    flag.setValue(true);
                }
            }
            // 递归查询子区域
            else if (region.getChildren() != null) {
                result.addAll(getRegionsByCode(region.getChildren(), code, flag));
            }
            // 当查到指定数据后,退出循环
            if(flag.getValue()) {
                break;
            }
        }
        return result;
    }

这样,我们就实现了,省市区三级联动,点击省,会展示出所有的省份,选中一个省,就会展示所有的市,选中一个市,就会展示所有的区。

相关推荐
深蓝海拓5 分钟前
PySide6从0开始学习的笔记(二十) qdarkstyle的深入应用
笔记·python·qt·学习·pyqt
ptc学习者14 分钟前
mysql 主从配置
数据库
网络风云17 分钟前
Flask 的 Docker 部署指南
python·docker·flask
飞天小蜈蚣22 分钟前
django的模板渲染、for循环标签、继承模板
数据库·python·django
飞Link22 分钟前
【Anaconda】Linux(CentOS7)下安装Anaconda教程
linux·运维·python
web3.088899930 分钟前
小红书笔记评论API接口详情展示
开发语言·笔记·python
手抄二进制31 分钟前
使用Anaconda创建python环境并链接到Jupyter
开发语言·python·jupyter
杨云龙UP39 分钟前
SQL Server 2016通过SSMS(SQL Server Management Studio)图形界面完成创建用户和授权_20251230
运维·服务器·数据库
源代码•宸40 分钟前
goframe框架签到系统项目开发(每日签到添加积分和积分记录、获取当月最大连续签到天数、发放连续签到奖励积分、实现签到日历详情接口)
数据库·经验分享·redis·中间件·golang·dao·goframe
知凡D44 分钟前
python脚本打包成exe后,对其引用的日历库实时更新-动态化加载模块
python·测试工具