guonan
2025-04-29 1f4c981d0076395c70c31f6edd851fb80a83443e
添加降雨数据
已修改2个文件
65 ■■■■ 文件已修改
src/store/simAPI.js 3 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/left/CitySim.vue 62 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/store/simAPI.js
@@ -71,7 +71,8 @@
                    prediction: forms.prediction,
                    history: forms.history,
                    mode: forms.mode,
                    gauges: forms.gauges
                    gauges: forms.gauges,
                    rainfalls: forms.rainFallList
                })
            }
            const res = await createSimData(params)
src/views/left/CitySim.vue
@@ -172,6 +172,7 @@
  intensity: "",
  fileList: [],
  type: 3,
  rainFallList: [],
});
const addSimCheme = async () => {
@@ -186,6 +187,7 @@
  forms.duration = "";
  forms.intensity = "";
  forms.fileList = [];
  forms.rainFallList = [];
};
// 计算属性:获取上传文件的名称列表
@@ -223,14 +225,29 @@
// 解析Excel文件
const parseExcel = (data) => {
  const workbook = XLSX.read(data, { type: "array" });
  console.log(workbook, "wokr");
  const firstSheetName = workbook.SheetNames[0];
  const worksheet = workbook.Sheets[firstSheetName];
  const jsonData = XLSX.utils.sheet_to_json(worksheet);
  const jsonData = XLSX.utils.sheet_to_json(worksheet, {
    raw: false, // 使用格式化字符串而不是原始值
    dateNF: "yyyy-mm-dd hh:mm:ss", // 指定日期格式
  });
  processData(jsonData);
};
const transformKeys = (data) => {
  return data.map((item) => ({
    time: item["时间"], // "时间" → "time"
    intensity: item["小时雨强mm/h"], // "小时雨强mm/h" → "intensity"
    total: item["累计雨量"], // "累计雨量" → "total"
  }));
};
// 处理数据
const processData = (data) => {
  forms.rainFallList = transformKeys(data);
  console.log(forms.rainFallList, "data");
  if (data.length === 0) return;
  const tableColumns = Object.keys(data[0]);
@@ -255,42 +272,53 @@
  forms.rainfall = lastValue; // 更新降雨量
};
// 解析日期时间
/**
 * 解析日期时间字符串或Excel数字日期,返回时间戳(毫秒数)
 * @param {string|number} dateString - 日期字符串或Excel数字日期
 * @returns {number} 时间戳(毫秒数),解析失败返回 NaN
 */
const parseDateTime = (dateString) => {
  // 1. 处理 Excel 数字日期(如 45136.91666666666),但是此处我在Excel解析时间的时候已经转换了,所以这个暂时无用
  if (typeof dateString === "number") {
    // 使用 XLSX 工具解析 Excel 日期编码
    const parsedDate = XLSX.SSF.parse_date_code(dateString);
    if (parsedDate) {
      // 转换为 JavaScript Date 对象并返回时间戳
      return new Date(
        parsedDate.y,
        parsedDate.m - 1,
        parsedDate.d,
        parsedDate.H || 0,
        parsedDate.M || 0,
        parsedDate.S || 0
      ).getTime();
        parsedDate.y, // 年
        parsedDate.m - 1, // 月(Excel 中 1-12,JS 中 0-11)
        parsedDate.d, // 日
        parsedDate.H || 0, // 时(可能不存在,默认为 0)
        parsedDate.M || 0, // 分(可能不存在,默认为 0)
        parsedDate.S || 0 // 秒(可能不存在,默认为 0)
      ).getTime(); // 返回时间戳
    }
  }
  // 2. 尝试直接解析日期字符串(如 "2023-07-30T16:00:00"),现在使用的是这个
  const parsedDate = new Date(dateString);
  if (!isNaN(parsedDate.getTime())) {
    return parsedDate.getTime();
    return parsedDate.getTime(); // 返回有效时间戳
  }
  const parts = dateString.split(/[/\s:]/);
  // 3. 处理自定义格式的日期字符串(如 "2023/07/30 16:00:00")
  const parts = dateString.split(/[/\s:]/); // 按 `/`、空格、`:` 分割
  if (parts.length >= 6) {
    const year = parseInt(parts[0], 10);
    const month = parseInt(parts[1], 10) - 1;
    const day = parseInt(parts[2], 10);
    const hour = parseInt(parts[3], 10) || 0;
    const minute = parseInt(parts[4], 10) || 0;
    const second = parseInt(parts[5], 10) || 0;
    const year = parseInt(parts[0], 10); // 年
    const month = parseInt(parts[1], 10) - 1; // 月(转换为 JS 的 0-11)
    const day = parseInt(parts[2], 10); // 日
    const hour = parseInt(parts[3], 10) || 0; // 时(默认 0)
    const minute = parseInt(parts[4], 10) || 0; // 分(默认 0)
    const second = parseInt(parts[5], 10) || 0; // 秒(默认 0)
    // 构造 Date 对象并返回时间戳
    const date = new Date(year, month, day, hour, minute, second);
    if (!isNaN(date.getTime())) {
      return date.getTime();
    }
  }
  // 4. 解析失败时警告并返回 NaN
  console.warn(`无法解析日期: ${dateString}`);
  return NaN;
};