在使用星原网关时,需要导入点表,由于设备的点表非常的多,可写的点表有1095个。
所有根据编码规律,编写了一段nodejs代码,来生成点表。
一个编码有四部分组成,
分别是
如 AA02-G,AH10-G
最后以csv格式保存文件,然后使用excel软件另存为xlsx格式。
二天的工作量,2个小时内完成, 而且可以重复,二次修改使用。
至此,生产力艺术已成。
const fs = require('fs')
const oneStrArr = ['A', 'B', 'C', 'D', 'E']
const twoStrArr = ['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H']
const threeStrArr = ['01', '02', '03', '04', '05', '06', '07', '08', '09', '10']
const colorArr = ['R', 'Y', 'G']
function initFun() {
const resArr = []
const resSwitchArr = []
for (let i = 0; i < oneStrArr.length; i++) {
const oi = oneStrArr[i]
for (let t = 0; t < twoStrArr.length; t++) {
const ti = twoStrArr[t]
for (let th = 0; th < threeStrArr.length; th++) {
const ri = threeStrArr[th]
// DB05-G
if (oi === 'D' && ti === 'B' && parseInt(ri) > 5) {
continue
}
// DD05-G
if (oi === 'D' && ti === 'D' && parseInt(ri) > 5) {
continue
}
// DF05-G
if (oi === 'D' && ti === 'F' && parseInt(ri) > 5) {
continue
}
// DF05-G; 没有DG,DH
if (oi === 'D' && ['G', 'H'].includes(ti)) {
continue
}
resSwitchArr.push(`${oi}${ti}${ri}-SWITCH`)
for (let c = 0; c < colorArr.length; c++) {
const ci = colorArr[c]
resArr.push(`${oi}${ti}${ri}-${ci}`)
}
}
}
}
return [resArr, resSwitchArr]
}
function getPoint(lightingArr) {
const pointArr = []
for (let i = 0; i < lightingArr.length; i++) {
const item = lightingArr[i]
const addr = Math.floor(i / 16) + 10
const dataType = i % 16
pointArr.push(`${item},第${i + 1}个灯,保持寄存器,${addr},BIT${dataType},可写,周期上报`)
}
return pointArr
}
const arr = initFun()
console.log('灯数量' + arr[0].length)
console.log('开关数量' + arr[1].length)
const pointArr = getPoint(arr[0])
// 使用fs.writeFile方法将字符串写入文件
fs.writeFile('lighting.txt', arr[0].join('\n'), err => {
if (err) throw err
console.log('文件已保存')
})
// 使用fs.writeFile方法将字符串写入文件
fs.writeFile('switch.txt', arr[1].join('\n'), err => {
if (err) throw err
console.log('文件已保存')
})
// 使用fs.writeFile方法将字符串写入文件
fs.writeFile('lighting.csv', pointArr.join('\n'), err => {
if (err) throw err
console.log('文件已保存')
})