|  | @ -16,11 +16,119 @@ async function makeDir (dir) { | 
			
		
	
		
		
			
				
					|  |  |    } |  |  |    } | 
			
		
	
		
		
			
				
					|  |  | } |  |  | } | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  | async function simpleExcelDown ({ data = [], header = [], fileName = moment().format('YYYY-MM-DD HH:mm:ss'), exp } = {}) { |  |  | async function gatherSheet ({ sheet_2, data = [] }) { | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    // header
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    const headerStyle = new xlsx.Style(); | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    headerStyle.align.h = 'center'; | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    headerStyle.align.v = 'center'; | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    headerStyle.border.right = 'thin'; | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    headerStyle.border.rightColor = '#000000'; | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    headerStyle.border.bottom = 'thin'; | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    headerStyle.border.bottomColor = '#000000'; | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    const headerRow1 = sheet_2.addRow(); | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    const indexCell1 = headerRow1.addCell(); | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    indexCell1.value = '南昌县农村公路养护管理暨用地范围内环境整治提升工程         考核汇总表' | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    indexCell1.style = headerStyle | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    indexCell1.hMerge = 12 | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    const headerRow2 = sheet_2.addRow(); | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    const indexCell2 = headerRow2.addCell(); | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    indexCell2.value = '责任单位' | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    indexCell2.style = headerStyle | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    indexCell2.vMerge = 1 | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    for (let h of ['县道', '', '', '', '乡道', '', '', '', '村道', '', '', '',]) { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       const cell = headerRow2.addCell(); | 
			
		
	
		
		
			
				
					|  |  |  |  |  |        | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       cell.value = h; | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       cell.style = headerStyle | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       if(h){ | 
			
		
	
		
		
			
				
					|  |  |  |  |  |          cell.hMerge = 3 | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       } | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    } | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    const header = [{ | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       key: '', | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       title: '', | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    },{ | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       key: 'county', | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       title: '总里程', | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    }, { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       key: 'countyParticipate', | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       title: '纳入考核里程', | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    }, { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       key: 'countyPresent', | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       title: '本次考核里程', | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    }, { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       key: 'county', | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       title: '实际抽取比原计划多', | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    }, { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       key: 'township', | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       title: '总里程', | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    }, { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       key: 'townshipParticipate', | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       title: '纳入考核里程', | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    }, { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       key: 'townshipPresent', | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       title: '本次考核里程', | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    }, { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       key: 'township', | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       title: '实际抽取比原计划多', | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    }, { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       key: 'village', | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       title: '总里程', | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    }, { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       key: 'villageParticipate', | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       title: '纳入考核里程', | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    }, { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       key: 'villagePresent', | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       title: '本次考核里程', | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    }, { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       key: 'village', | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       title: '实际抽取比原计划多', | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    },] | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    const headerRow3 = sheet_2.addRow(); | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    for (let h of header) { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       const cell = headerRow3.addCell(); | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       cell.value = h.title; | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       cell.style = headerStyle | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    } | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    // data
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    // const style = new xlsx.Style();
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    // style.align.h = 'left';
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    // style.align.v = 'center';
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    // style.border.right = 'thin';
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    // style.border.rightColor = '#000000';
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    // style.border.bottom = 'thin';
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    // style.border.bottomColor = '#000000';
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    // for (let i = 0; i < data.length; i++) {
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    //    const row = sheet_2.addRow();
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    //    const indexCell = row.addCell();
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    //    indexCell.value = i + 1
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    //    indexCell.style = headerStyle
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    //    for (let h of header) {
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    //       const cell = row.addCell();
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    //       cell.value = data[i][h.key];
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    //       cell.style = style
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    //    }
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    // }
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  | } | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  | async function simpleExcelDown ({ data = [], header = [], fileName = moment().format('YYYY-MM-DD HH:mm:ss'), exp, gather } = {}) { | 
			
		
	
		
		
			
				
					|  |  |    const fileDirPath = path.join(__dirname, `../../downloadFiles`) |  |  |    const fileDirPath = path.join(__dirname, `../../downloadFiles`) | 
			
		
	
		
		
			
				
					|  |  |    makeDir(fileDirPath) |  |  |    makeDir(fileDirPath) | 
			
		
	
		
		
			
				
					|  |  |    const file = new xlsx.File(); |  |  |    const file = new xlsx.File(); | 
			
		
	
		
		
			
				
					|  |  |    const sheet_1 = file.addSheet('sheet_1'); |  |  |    const sheet_1 = file.addSheet('sheet_1'); | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    if (gather) { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       const sheet_2 = file.addSheet('sheet_2'); | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       await gatherSheet({ sheet_2, ...gather }) | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    } | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |    // header
 |  |  |    // header
 | 
			
		
	
		
		
			
				
					|  |  |    const headerStyle = new xlsx.Style(); |  |  |    const headerStyle = new xlsx.Style(); | 
			
		
	
	
		
		
			
				
					|  | @ -99,6 +207,8 @@ async function simpleExcelDown ({ data = [], header = [], fileName = moment().fo | 
			
		
	
		
		
			
				
					|  |  |    return savePath |  |  |    return savePath | 
			
		
	
		
		
			
				
					|  |  | } |  |  | } | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  | module.exports = { |  |  | module.exports = { | 
			
		
	
		
		
			
				
					|  |  |    simpleExcelDown |  |  |    simpleExcelDown | 
			
		
	
		
		
			
				
					|  |  | } |  |  | } |