| | |
| | | // 计算结果 |
| | | private val result = mutableSetOf<BaseEffect>() |
| | | |
| | | private val rMap = mutableMapOf<String, MutableMap<String, MutableMap<String?, MutableList<Double>>>>() |
| | | |
| | | // 结果筛选方式 |
| | | abstract var sections: List<BaseSection<M, S>> |
| | | |
| | |
| | | */ |
| | | fun execute(mDataList: List<M>, sopList: List<S>) { |
| | | result.clear() |
| | | rMap.clear() |
| | | |
| | | //1. 数据预处理 |
| | | val mList = dataPrep.mDataPrep(mDataList) |
| | |
| | | sections.forEach { it.filter(mData, sop, effect) } |
| | | |
| | | // 保存结果 |
| | | result.add(effect) |
| | | // result.add(effect) |
| | | formatConversion2(effect) |
| | | } |
| | | |
| | | fun outputToExcel( |
| | |
| | | sheetName: String = "sheet1", |
| | | done: Boolean = true |
| | | ): Pair<HSSFWorkbook, FileOutputStream>? { |
| | | val rMap = formatConversion() |
| | | // val rMap = formatConversion() |
| | | |
| | | val workbook = _workbook ?: HSSFWorkbook() |
| | | val fileName = fName ?: "污染溯源权重模型${DateUtil().DateToString(Date(), "yyyy-MM-ddHHmmss")}.xls" |
| | |
| | | return rMap |
| | | } |
| | | |
| | | private fun formatConversion2(e: BaseEffect) { |
| | | val rKey = "${e.sourceName}(${e.index})" |
| | | if (!rMap.containsKey(rKey)) { |
| | | rMap[rKey] = mutableMapOf() |
| | | } |
| | | val lMap = rMap[rKey]!! |
| | | e.value.forEach { v -> |
| | | if (!lMap.containsKey(v.first.des)) { |
| | | lMap[v.first.des] = mutableMapOf() |
| | | } |
| | | val tMap = lMap[v.first.des]!! |
| | | e.tag.forEach { t -> |
| | | val factorName = v.first.des |
| | | val lKey = t.levelName + "($factorName)" |
| | | if (!tMap.containsKey(lKey)) { |
| | | tMap[lKey] = mutableListOf() |
| | | } |
| | | tMap[lKey]?.add(v.second) |
| | | } |
| | | } |
| | | } |
| | | |
| | | /** |
| | | * 监测数据合法性检查 |
| | | */ |