首页 > 其他分享 >综合设计——多源异构数据采集与融合应用综合实践

综合设计——多源异构数据采集与融合应用综合实践

时间:2024-12-17 17:21:08浏览次数:3  
标签:异构 数据 多源 formData recruitment API data 综合 jobDetail

职途启航:数据采集项目实践

项目信息

项目概述

互联网的发展催生了众多招聘 APP,为求职者提供了丰富就业选择。但随着行业细分,求职者常迷茫于自身技能与工作经历适配的岗位。且不同城市主导行业各异,相同行业在各地薪资与前景截然不同,选择合适城市也至关重要。本项目应运而生,旨在为求职者精准匹配招聘信息,并提供各省份各行业发展情况作为参考。

成员分工

成员编号 角色 职责
成员 1 项目经理 & 前端开发 - 项目整体规划与进度管理
- 团队协调与沟通保障
- 前端界面设计与开发
- 前后端数据交互协作
成员 2 后端开发 & 数据采集分析师 - 后端逻辑与 API 开发
- 数据库管理
- 参与数据采集,确保数据准确及时
- 与前端团队协作,保障数据正确展示
成员 3 后端开发 - 专注于后端服务开发
- 服务器端逻辑与数据库交互
- 与数据采集团队合作,优化数据处理
成员 4 前端开发 & 数据采集分析师 - 前端界面开发,保障美观与易用性
- 参与数据采集,确保数据展示准确
成员 5 数据采集分析师 - 从招聘网站爬取岗位、薪资、行业趋势等数据
- 数据清洗与分析
- 为智能推荐服务提供数据支持
成员 6 数据采集分析师 - 与成员 5 协作,负责数据采集与分析
- 确保数据质量与分析准确性

个人分工

从招聘网站爬取岗位、薪资、行业趋势等数据

  • 数据清洗与分析
  • 为智能推荐服务提供数据支持

核心代码

FujianRecruitmentView.vue

async fetchRecruitments() {
      const savedRecruitments = localStorage.getItem('recruitments');
      if (savedRecruitments) {
        this.originalRecruitments = JSON.parse(savedRecruitments);
        this.allRecruitments = this.setDefaultOccupationType([...this.originalRecruitments]);
        this.allRecruitments.forEach(recruitment => {
          recruitment.Location = recruitment.Location.trim();
          recruitment.Occupation_Type = recruitment.Occupation_Type? recruitment.Occupation_Type.trim() : '未知';
        });
        this.resetRecruitments();
      } else {
        try {
          const response = await axios.get('http://81.70.22.101:5000/province-recruitment');
          if (response.data.code === 200) {
            this.originalRecruitments = response.data.data;
            this.allRecruitments = this.setDefaultOccupationType([...this.originalRecruitments]);
            this.allRecruitments.forEach(recruitment => {
              recruitment.Location = recruitment.Location.trim();
              recruitment.Occupation_Type = recruitment.Occupation_Type? recruitment.Occupation_Type.trim() : '未知';
            });
            this.resetRecruitments();
          } else {
            console.error(response.data.message);
            this.allRecruitments = [];
            this.visibleRecruitments = [];
          }
        } catch (error) {
          console.error('Error fetching recruitments:', error);
          this.allRecruitments = [];
          this.visibleRecruitments = [];
        }
      }
    },

IntelligentRecommendationInputView.vue

this.isLoading = true; // 开始加载
      try {
        // 发送获取匹配职位的 API 请求
        const response1 = await axios.post('http://81.70.22.101:5000/api/recommend_career_advice', {
          desired_position: this.formData.jobs.join(', '), // 转化成逗号分隔字符串
          expected_salary: this.formData.salary,
          resume: this.formData.bio,
          requirements: this.formData.requirements,
          work_experience: this.formData.experience
        });

        // 发送获取职业规划建议的 API 请求
        const response2 = await axios.post('http://127.0.0.1:5000/recommend-career-advice', {
          desired_position: this.formData.jobs.join(', '),
          expected_salary: this.formData.salary,
          resume: this.formData.bio,
          requirements: this.formData.requirements,
          work_experience: this.formData.experience
        });

        // 检查两个接口的响应状态
        console.log('Response1:', response1);
        console.log('Response2:', response2);

        if (response1.data.code === 200 && response2.data.code === 200) {
          // 将匹配职位和职业规划建议保存到 Vuex 中
          this.$store.dispatch('saveRecommendedJobs', response1.data.data);  // 保存职位数据
          this.$store.dispatch('saveCareerAdvice', response2.data.data);  // 保存职业规划数据

          // 跳转到结果页面
          console.log('Navigating to result page');
          this.$router.push('/intelligent-recommendation-result');
        } else {
          this.errorMessage = response1.data.message || response2.data.message || '获取匹配职位失败';
        }

IntelligentRecommendationResultView.vue

<script>
import Header from "../components/Header.vue";

export default {
  name: "IntelligentRecommendationResultView",
  components: {
    Header,
  },
  data() {
    return {
      // 从 Vuex 获取推荐职业数据
      recommendedJobs: this.$store.state.recommendedJobs,
      tabs: ["岗位现状", "职位面试", "就职方向", "人际沟通"],
      activeTab: "岗位现状", // 默认选中的标签
      currentContent: "", // 当前显示的文本内容
    };
  },
  mounted() {
    this.fetchTabContent();
  },
  methods: {
    goToRecruitmentDetail(id) {
      this.$router.push(`/recruitment-detail/${id}`);
    },
    changeTab(tab) {
      this.activeTab = tab;
      this.fetchTabContent();
    },
    fetchTabContent() {
      // 获取职业规划建议内容
      const careerAdvice = this.$store.state.careerAdvice;

      switch (this.activeTab) {
        case "岗位现状":
          this.currentContent = careerAdvice.Current_Situation || "暂无内容";
          break;
        case "职位面试":
          this.currentContent = careerAdvice.Interview_Advice || "暂无内容";
          break;
        case "就职方向":
          this.currentContent = careerAdvice.Career_Direction || "暂无内容";
          break;
        case "人际沟通":
          this.currentContent = careerAdvice.Communication_Skills || "暂无内容";
          break;
        default:
          this.currentContent = "暂无内容";
      }
    },
  },
};
</script>

NationalEmploymentView.vue

// 监听地图点击事件
      myChart.on('click', (params) => {
        this.selectedProvince = params.name; // 获取点击的省份名称
        this.navigateToProvincePage(this.selectedProvince, module);
      });
    },

    // 导航到对应的省份页面并在新窗口中打开
    navigateToProvincePage(provinceName, module) {
      let url;
      if (module === 'industryAverageSalary') {
        url = `http://81.70.22.101:5000/${provinceName}`; // 行业平均工资页面
      } else if (module === 'industryPopulationChange') {
        url = `http://81.70.22.101:5000/api/${provinceName}`; // 行业人数变化页面
      }
      // 在新窗口中打开 URL
      window.open(url, '_blank');
    },
  },

IntelligentRecommendationResultView.vue

 methods: {
    async fetchJobDetail() {
      try {
        const recruitmentId = this.$route.params.id; // 使用 'id' 而不是 'recruitment_id'
        const response = await axios.get('http://81.70.22.101:5000/recruitment-detail', {
          params: {
            id: recruitmentId  // 传递正确的参数名
          }
        });

        if (response.data.code === 200) {
          this.jobDetail = response.data.data; // 赋值给 jobDetail
        } else {
          console.error('Error fetching job details:', response.data.message);
        }
      } catch (error) {
        console.error('API request failed:', error);
      }
    },
    goBack() {
      this.$router.go(-1); // 返回上一页
    },
    prevImage() {
      if (this.jobDetail.Company_Photo && this.jobDetail.Company_Photo.length > 0) {
        this.currentImageIndex = (this.currentImageIndex - 1 + this.jobDetail.Company_Photo.length) % this.jobDetail.Company_Photo.length;
      }
    },
    nextImage() {
      if (this.jobDetail.Company_Photo && this.jobDetail.Company_Photo.length > 0) {
        this.currentImageIndex = (this.currentImageIndex + 1) % this.jobDetail.Company_Photo.length;
      }
    }

收获

  1. 深度洞悉 Vue3:深度融入项目实践,对 Vue3 的响应式系统、组件化架构以及 Composition API 实现了全方位透彻理解。依托这些关键技术要素,成功塑造出兼具高效运行机制与卓越可维护性的前端应用范例,在架构设计与代码实现层面均实现质的飞跃。
  2. 精通可视化应用构建:熟练驾驭 Vue3 技术核心,巧妙融合 ECharts 等前沿数据可视化库,匠心打造出一系列直观且极具洞察力的图表模块,以及高效的数据展示页面。此举不仅使应用的交互体验焕然一新,更让数据蕴含的关键信息得以精准、流畅地传达给用户,显著提升了应用的实用价值与用户吸引力。
  3. 沉淀前后端交互实战心得:全程主导项目中的前后端交互环节,从 API 的精心设计、高效调用,到严谨的测试流程,均亲力亲为。借助 Axios 这一强大工具进行 HTTP 请求处理,凭借对其丰富特性的精准把握,全方位保障了数据在前后端传输通道中的准确性、完整性与及时性,为系统稳定运行筑牢根基。
  4. 精研 API 调用与测试之道:秉持严谨专业态度,深度参与 API 接口的全方位测试工作。通过精心编写单元测试用例,搭配 Postman 等行业领先工具的灵活运用,对 API 的性能表现、数据交互逻辑进行了反复打磨与优化,有力确保了 API 在各种复杂业务场景下的稳定运行,为系统集成提供坚实技术支撑。
  5. 练就卓越问题解决本领:直面项目进程中层出不穷的技术难题,锤炼出一套行之有效的问题分析与解决策略。以 Vue3 跨域问题为例,凭借对网络原理与前端技术架构的深刻洞察,巧妙运用代理服务器配置及 CORS 策略精细调校,成功打破技术瓶颈,扫清项目障碍,积累了宝贵的实战排障经验。
  6. 深化前端技术栈造诣:历经此项目的高强度锤炼,对前端技术栈的理解从基础应用迈向深度精通。无论是 HTML、CSS、JavaScript 的经典组合,还是 Vue3 独有的创新特性,如 Fragments 的高效组件渲染、Teleport 的灵活 DOM 插入以及 Suspense 的异步加载优化,均能信手拈来,融会贯通,实现技术能力的全面进阶。
  7. 磨砺时间管理与团队引领能力:置身于紧张高压的项目周期中,精准拿捏时间分配与资源调度的艺术,巧妙制定详细周密的项目计划,确保每个关键节点按时推进,成功引领项目如期交付。同步提升团队领导素养,善于激发团队成员潜能,精准把控项目走向,持续营造积极向上、协作共进的团队氛围,铸就高效执行团队。

标签:异构,数据,多源,formData,recruitment,API,data,综合,jobDetail
From: https://www.cnblogs.com/zck-102202122/p/18613011

相关文章

  • ssmToB企业版招聘类综合网站5u96c(程序+源码+数据库+调试部署+开发环境)
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表开题报告内容一、项目背景与意义随着互联网技术的不断发展,企业招聘方式逐渐由线下转向线上。为了满足企业对高效、精准招聘的需求,本项目旨在设计并实现一款面向......
  • 多源最短路Floyd算法
    多源最短路算法-Floyd使用Floyd(弗洛伊德)算法,可以以\(O(n^3)\)的时间复杂度求出一张多源图的任意两点间的最短路径一般采用邻接矩阵的方法来存储图:intg[N][N];g[i][j]其中,g[i][j]的意义为第i个节点到第j个节点的权重我们需要对邻接矩阵进行路径初始化,将自身到自身的权重......
  • 综合设计 ——多源异构数据采集与融合应用综合实践
    综合设计——多源异构数据采集与融合应用综合实践#综合设计——多源异构数据采集与融合应用综合实践码云地址这个项目属于哪个课程<班级的链接>组名、项目简介组名:黑马楼:直面爬虫项目需求:实现宠物具体种类的识别项目目标:根据用户上传的文本和图片识别具体的宠物......
  • 综合设计——多源异构数据采集与融合应用综合实践
    这个项目属于哪个课程https://edu.cnblogs.com/campus/fzu/2024DataCollectionandFusiontechnology/组名、项目简介组名:都给爷爬项目目标:为心理疾病患者进行个性化的音乐疗愈项目需求:市面上大多数音乐软件都需要会员而且存在打榜等现象,不能完全个性化推荐,我们希望我们的......
  • 多源异构数据采集与融合应用综合实践
    这个项目属于哪个课程2024数据采集与融合技术实践组名、项目简介组名:scrapy能帮我爬到美味蟹黄堡的秘方吗项目需求:文物不能很好的融入我们的生活,它们仿佛一具冰冷的尸体躺在博物馆的展示柜中,静静地接受着岁月的侵蚀和尘埃的覆盖。项目目标:赋予文物新的生命力,让它们“动......
  • 福卫兵——多源异构数据采集与融合应用综合实践
    福州大学多模态网络舆情分析与可视化系统序号信息类别内容描述1这个项目属于哪个课程数据采集与融合综合实践2组名、项目简介组名:福小兵,项目需求:实时舆情监控系统,项目目标:为福州大学提供舆情监控与决策辅助工具,技术路线:使用Flask后端、Memfire(PostgreSQL)数......
  • 综合设计——多源异构数据采集与融合应用综合实践
    Gitee项目链接:https://gitee.com/wei-yuxuan6/myproject/tree/master/实践作业这个项目属于哪个课程https://edu.cnblogs.com/campus/fzu/2024DataCollectionandFusiontechnology组名在大大的数据里面挖呀挖呀挖项目简介项目名称:城市记忆Logo:项目需求:整合城市......
  • 综合设计——多源异构数据采集与融合应用综合实践
    这个项目属于哪个课程2024数据采集与融合技术实践组名在大大的数据里面挖呀挖呀挖项目简介项目名称:城市记忆Logo:项目需求:整合城市历史文化资源:需要以交互式的方式展示城市的历史发展、新旧照片、方言特色以及名人故事等内容。增强用户参与感:为用户提供交互性......
  • 综合设计——多源异构数据采集与融合应用综合实践
    序号信息类别内容描述1这个项目属于哪个课程数据采集与融合综合实践2组名、项目简介组名:福小兵项目需求:实时舆情监控系统项目目标:为福州大学提供舆情监控与决策辅助工具技术路线:使用Flask后端、Memfire(PostgreSQL)数据库和Vue前端技术栈,建立从数据采集到情......
  • 综合设计 ——多源异构数据采集与融合应用综合实践
    综合设计——多源异构数据采集与融合应用综合实践码云地址这个项目属于哪个课程<班级的链接>组名、项目简介组名:黑马楼:直面爬虫项目需求:实现宠物具体种类的识别项目目标:根据用户上传的文本和图片识别具体的宠物种类项目开展技术路线:html,css,js,flask团队成员......