Browse Source

更正错别字

dev
CODE 1 year ago
parent
commit
371bfb5a40
  1. 4
      api/app/lib/controllers/report/index.js
  2. 4
      api/app/lib/models/village_distance.js
  3. 2
      scripts/1.4.0/data/1_calc_village_distance/Dockerfilenew
  4. 38
      scripts/1.4.0/data/1_calc_village_distance/index.js
  5. 4
      scripts/1.4.0/schema/2.create_village_table.sql

4
api/app/lib/controllers/report/index.js

@ -698,9 +698,9 @@ async function roadSpotPrepare (ctx) {
} }
const villageNearRes = await sequelize.query(` const villageNearRes = await sequelize.query(`
SELECT id,calc_village,diatance FROM village_distance SELECT id,calc_village,distance FROM village_distance
WHERE origin_village = ${spotFirstVillageId} WHERE origin_village = ${spotFirstVillageId}
ORDER BY diatance ASC ORDER BY distance ASC
`, { type: QueryTypes.SELECT }) `, { type: QueryTypes.SELECT })
let villageCheckIdList = villageNearRes.map(item => item.calc_village) let villageCheckIdList = villageNearRes.map(item => item.calc_village)

4
api/app/lib/models/village_distance.js

@ -41,13 +41,13 @@ module.exports = dc => {
model: "village" model: "village"
} }
}, },
diatance: { distance: {
type: DataTypes.INTEGER, type: DataTypes.INTEGER,
allowNull: true, allowNull: true,
defaultValue: null, defaultValue: null,
comment: "距离 m", comment: "距离 m",
primaryKey: false, primaryKey: false,
field: "diatance", field: "distance",
autoIncrement: false autoIncrement: false
} }
}, { }, {

2
scripts/1.4.0/data/1_calc_village_distance/Dockerfilenew

@ -1,5 +1,5 @@
FROM repository.anxinyun.cn/base-images/nodejs12:20.10.12.2 FROM repository.anxinyun.cn/base-images/nodejs12:20.10.12.2
COPY ./scripts/1.3.1/data/1_insert_report_data /var/app COPY ./scripts/1.4.0/data/1_calc_village_distance /var/app
WORKDIR /var/app WORKDIR /var/app
RUN npm cache clean -f RUN npm cache clean -f
RUN rm -rf package-lock.json RUN rm -rf package-lock.json

38
scripts/1.4.0/data/1_calc_village_distance/index.js

@ -11,6 +11,7 @@ try {
password: '123', password: '123',
database: 'highways4good', database: 'highways4good',
}) })
const godKey = '21c2d970e1646bb9a795900dd00093ce'
function getDistance (lat1, lon1, lat2, lon2) { function getDistance (lat1, lon1, lat2, lon2) {
var R = 6371000; // 半径 of the earth in meters var R = 6371000; // 半径 of the earth in meters
@ -44,12 +45,24 @@ try {
await client.query('BEGIN') await client.query('BEGIN')
console.log(`开始`); console.log(`开始`);
// 遍历南昌县所有村 const nanchangRes = await request.get(`https://restapi.amap.com/v3/config/district?key=${godKey}&keywords=360100&subdistrict=1`)
console.log(nanchangRes.body);
let townshipList = nanchangRes.body.districts[0].districts
console.log(townshipList);
for (let t of townshipList) {
console.log(`${t.name}`);
let pageNum = 1 let pageNum = 1
let continueSearch = true let continueSearch = true
for (; continueSearch;) { for (; continueSearch;) {
console.log(`查询第${pageNum}`); console.log(`查询第${pageNum}`);
const res = await request.get(`https://restapi.amap.com/v5/place/text?key=21c2d970e1646bb9a795900dd00093ce&keywords=%E6%9D%91%E5%A7%94%E4%BC%9A%7C%E6%9D%91%E6%B0%91%E5%A7%94%E5%91%98%E4%BC%9A&types=130106&region=360121&citylimit=true&page_size=25&page_num=${pageNum}&extensions=all`) // const res = await request.get(`https://restapi.amap.com/v5/place/text?key=${godKey}&types=130106&region=360000&citylimit=true&page_size=25&page_num=${pageNum}&extensions=all`)
const res = await request.get(`https://restapi.amap.com/v3/place/text?key=${godKey}&keywords=%E6%9D%91%E5%A7%94%E4%BC%9A%7C%E6%9D%91%E6%B0%91%E5%A7%94%E5%91%98%E4%BC%9A&page_size=25&types=130106&citylimit=true&city=${t.adcode}&page=${pageNum}`)
await new Promise(resolve => setTimeout(() => resolve(), 2000));
// console.log(res.body); // console.log(res.body);
const data = res.body const data = res.body
@ -61,6 +74,7 @@ try {
pageNum++ pageNum++
} }
for await (let p of data.pois) { for await (let p of data.pois) {
console.log(p.name);
if (p.name.includes('村委会') || p.name.includes('村民委员会')) { if (p.name.includes('村委会') || p.name.includes('村民委员会')) {
let vName = p.name.replace('村委会', '').replace('村民委员会', '').replace(/\(.*?\)/g, '') let vName = p.name.replace('村委会', '').replace('村民委员会', '').replace(/\(.*?\)/g, '')
@ -81,19 +95,26 @@ try {
vName = vName + '村' vName = vName + '村'
} }
console.log(`${vName}`); // console.log(`${vName}`);
let locationArr = p.location.split(',') let locationArr = p.location.split(',')
// 查询镇名是否存在 // 查询镇名是否存在
const existRes = await client.query( let existRes = await client.query(
`SELECT * FROM village WHERE name=$1`, `SELECT * FROM village WHERE name=$1`,
[vName] [vName]
) )
if (existRes.rowCount == 0) {
existRes = await client.query(
`SELECT * FROM village WHERE name=$1`,
[vName + '委会']
)
}
if (existRes.rowCount == 0) { if (existRes.rowCount == 0) {
} else { } else {
let existV = existRes[0] let existV = existRes.rows[0]
// console.log(existRes);
await client.query( await client.query(
`UPDATE village SET longitude=$1, latitude=$2 WHERE id=$3`, `UPDATE village SET longitude=$1, latitude=$2 WHERE id=$3`,
[locationArr[0], locationArr[1], existV.id] [locationArr[0], locationArr[1], existV.id]
@ -102,6 +123,7 @@ try {
} }
} }
} }
}
const allVillagesRes = await client.query( const allVillagesRes = await client.query(
`SELECT * FROM village` `SELECT * FROM village`
@ -121,7 +143,8 @@ try {
continue continue
} }
let distance = getDistance(v.latitude, v.longitude, vv.latitude, vv.longitude) let distance = getDistance(v.latitude, v.longitude, vv.latitude, vv.longitude)
console.log(`${v.name}${vv.name} 的距离为 ${distance}`);
// console.log(`${v.name} 与 ${vv.name} 的距离为 ${distance} 米`);
distance = Math.round(distance) distance = Math.round(distance)
const existRes = await client.query( const existRes = await client.query(
@ -134,8 +157,9 @@ try {
[v.id, vv.id, distance] [v.id, vv.id, distance]
) )
} else { } else {
let upSql = `UPDATE village_distance SET distance=$1 WHERE origin_village=$2 AND calc_village=$3`
await client.query( await client.query(
`UPDATE village_distance SET distance=$1 WHERE origin_village=$2 AND calc_village=$` upSql
, [distance, v.id, vv.id] , [distance, v.id, vv.id]
) )
} }

4
scripts/1.4.0/schema/2.create_village_table.sql

@ -34,7 +34,7 @@ create table if not exists village_distance
calc_village integer calc_village integer
constraint village_distance_village_id_fk_2 constraint village_distance_village_id_fk_2
references village, references village,
diatance integer distance integer
); );
comment on table village_distance is '村之间的距离'; comment on table village_distance is '村之间的距离';
@ -43,7 +43,7 @@ comment on column village_distance.origin_village is '原点村庄';
comment on column village_distance.calc_village is '相对计算村庄'; comment on column village_distance.calc_village is '相对计算村庄';
comment on column village_distance.diatance is '距离 m'; comment on column village_distance.distance is '距离 m';
create unique index if not exists village_distance_id_uindex create unique index if not exists village_distance_id_uindex
on village_distance (id); on village_distance (id);

Loading…
Cancel
Save