查询全球国家城市地区的接口

京东商城 商品详情页 找到了一个 省市区街道 API 接口, 这是一个没有跨域问题 JSONP用的接口, 如果我们不传 callback 就可以直接使用。

接口放在下面

js 复制代码
例如查国家(全球国家):
https://fts.jd.com/area/get?fid=-1
// 直接浏览器运行即可
// fid=-1 为国家,查其它可以将fid 为 接口 返回的id,进行下级查询。

// 后面查省直接把fid换成对应国家的id的值
// 查地区直接把fid换成对应省的id的值
// 如查中国的省份(fid换成中国的id)
https://fts.jd.com/area/get?fid=4744
// 查河南省的市(fid换成河南省的id)
https://fts.jd.com/area/get?fid=7
// 查河南省周口市的街道(fid换成周口市的id)
https://fts.jd.com/area/get?fid=527

如果想爬取下来所有 中国的省市区 信息,可以可运行下面的 NodeJS 代码

js 复制代码
const axios = require('axios')
const fs = require('fs')

const sleep = async ms => new Promise(resolve => setTimeout(resolve, ms))

async function getArea(fid = -1) {
  const { data } = await axios.get(`https://fts.jd.com/area/get?fid=${fid}`)
  return data
}

async function makePlainArea(plain = [], fid = 4744) {
  await sleep(500 + Math.random() * 500)
  let areas = await getArea(fid)
  // areas = areas.slice(0, 3) // 测试
  if (!areas.length) {
    return
  }
  for (let area of areas) {
    area.pid = fid
    plain.push(area)
    console.log('即将获取:' + area.name)
    await makePlainArea(plain, area.id)
  }
}

async function main() {
  const plain = []
  await makePlainArea(plain, 4744)
  fs.writeFileSync('./plain-area.json', JSON.stringify(plain))
  console.log('生成完毕')
}

main().catch(console.log)

将 扁平的 数据 转 树结构 参考:

JS 将扁平后的数据 恢复成 树结构

相关推荐
冷凌爱38 分钟前
Fetch与Axios:区别、联系、优缺点及使用差异
前端·node.js·js
Sailing1 小时前
Grafana-mcp-analyzer:基于 MCP 的轻量 AI 分析监控图表的运维神器!
前端·node.js·mcp
XI锐真的烦2 小时前
横向对比npm和yarn
前端·npm·node.js
穗余2 小时前
WEB3全栈开发——面试专业技能点P1Node.js / Web3.js / Ethers.js
javascript·node.js·web3
贩卖纯净水.19 小时前
Webpack的基本使用 - babel
前端·webpack·node.js
贩卖纯净水.20 小时前
Webpack依赖
前端·webpack·node.js
笑醉踏歌行1 天前
NVM,Node.Js 管理工具
运维·ubuntu·node.js
chxii1 天前
1.4 Node.js 的 TCP 和 UDP
node.js
xd000022 天前
11. vue pinia 和react redux、jotai对比
node.js
程序猿小D2 天前
第16节 Node.js 文件系统
linux·服务器·前端·node.js·编辑器·vim