中秋前夕-我居然使用技术来鞭策兄弟

news2025/1/22 18:10:25

中秋前夕-我居然使用技术来鞭策兄弟

前言

最近在带领一些小伙伴在完成功能,因为人数不少,那么我们如何统计大家有没有摸鱼偷懒呢?

聪明的朋友们可以想到,利用git的提交记录统计。

因为git提交时,会给我们带上一些关键的信息。如

  1. 提交的次数 - 提交次数多,就认为该伙计是个好🐮🐴
  2. 提交的备注 - 具体看到提交的内容
  3. 最后提交的日期 - 提交的日期时间越晚(比如熬夜),就认为该伙计是个好🐮🐴

定下了目标,那么就开始分析如何实现吧

分析

附带流程图

  1. 引导填写姓名和git仓库
  2. 整理成json格式
  3. 使用axios 和 cheeir 获取目标数据
  4. node注入到html中
  5. 渲染成表格或者图表

image-20240916212632780

引导填写姓名和git仓库

可以通过在线表格的方式让小伙伴填写自己的姓名和仓库。如:

image-20240916205007101

整理成json格式

这个如果熟练使用工具的小伙伴应该可以很快完成这个操作。

最后到手是这个数据格式

注意,url 需要替换成自己的码云git地址

[
  {
    "name": "万小弟1",
    "url": "https://www.baidu.com/s?wd=%E7%99%BE%E5%BA%A6&tn=25017023_2_dg&ch=8&ie=utf-8"
  },
  {
    "name": "万小弟2",
    "url": "https://www.baidu.com/s?wd=%E7%99%BE%E5%BA%A6&tn=25017023_2_dg&ch=8&ie=utf-8"
  },
  {
    "name": "万小弟3",
    "url": "https://www.baidu.com/s?wd=%E7%99%BE%E5%BA%A6&tn=25017023_2_dg&ch=8&ie=utf-8"
  }
]

使用axios 和 cheeir 获取目标数据

虽然码云提供了openAPI,但是你如果短时间内多发几次ajax请求,那么码云后端就会封禁你了。你再发就是403

image-20240916210331637

因此我们通过node,在后端直接请求目标页面,然后直接解析 整个html即可。

新建一个英文文件夹

image-20240916210446320

目录内初始化

打开终端,输入

npm init -y 

得到项目描述文件

image-20240916210545594

安装相关依赖

  1. axios 发送http请求
  2. cheerio 解析 html字符
npm i axios cheerio 

新建需要遍历的数据文件

data.json

也就是刚才整理好的json文件

[
  {
    "name": "万小弟1",
    "url": "https://gitee.com/ukSir/GGMusic"
  },
  {
    "name": "万小弟2",
    "url": "https://gitee.com/ukSir/GGMusic"
  },
  {
    "name": "万小弟3",
    "url": "https://gitee.com/ukSir/GGMusic"
  }
]

新建node程序入口文件

index.js

const axios = require('axios')
const cheerio = require('cheerio')

// 引入数据文件
let list = require("./data.json")

async function getMainContent(target_url, name) {
  // 发送get请求
  const res = await axios.get(target_url)
  // 获取返回的页面数据
  const html = res.data
  // 使用 cheerio 加载返回的内容数据 后面可以通过 $ 类似jquery的方式来获取html中的内容
  const $ = cheerio.load(html)

}

// 遍历数据发送请求
list.forEach(item => {
  getMainContent(item.url, item.name)
})

获取码云页面上需要收集的数据

  1. 提交次数

    image-20240916211603919

    可以看到提交次数的关键标签的选择器为 all-commits

    那么我们可以使用刚才的 cheerio 来读取它的数据

    let commitTimes = $(".all-commits").text()
    

    如果想要只获取它的数字部分,那么使用正则简单解析下即可

    let commitTimes = $(".all-commits").text()
    commitTimes = commitTimes.replace(/\s/g, '').match(/\w+/g)[0]
    
  2. 最后提交日期

    同理

    image-20240916211850569

    const lastTime = $(".timeago").prop("datetime")
    
  3. 最后提交备注

    image-20240916211951968

    const comment = $(".repo-index-commit-msg").prop("title")
    

拼接数据

获取到想要的关键数据后,可以开始拼接成自己想要的数据了

image-20240916212140114

const axios = require('axios')
const cheerio = require('cheerio')
let list = require("./data.json")
const fs = require("fs")
// 想要拼接的数据数组
let resultList = []

async function getMainContent(target_url, name) {
  try {
    const res = await axios.get(target_url)
    const html = res.data
    const $ = cheerio.load(html)
    let commitTimes = $(".all-commits").text()
    commitTimes = commitTimes.replace(/\s/g, '').match(/\w+/g)[0]
    const lastTime = $(".timeago").prop("datetime")
    const comment = $(".repo-index-commit-msg").prop("title")
    // console.log(commitTimes, lastTime, comment)
    resultList.push({
      "姓名": name,
      "提交次数": commitTimes,
      "最后提交日期": lastTime,
      "最近提交记录": comment,
      "git地址": `<a target="_blank" href="${target_url}">git地址</a>`
    })
  } catch (e) {
    resultList.push({
      "姓名": name,
      "提交次数": 0,
      "最后提交日期": 0,
      "最近提交记录": `<b>地址错误</b>`,
      "git地址": `<a target="_blank" href="${target_url}">git地址</a>`
    })
  }
  finally {
    if (resultList.length === list.length) {
        // resultList 为拼接好的数组
    }
  }
}


list.forEach(item => {
  getMainContent(item.url, item.name)
})

node注入到html中

这个步骤的具体目标是想要将生成的数据可以直接注入到html,然后打开html便可直接观察到了。如

image-20240916212952185


image-20240916213007730

准备好html模板

这个其实也是服务端渲染的流程,先提前将模板准备好,然后通过node读取,当成字符来处理,注入数据即可

新建模板文件 index.html

下图中的 ${ script } 是自定义的标记,可以根据自己爱好来定义

image-20240916213339272

node中开始注入

先读取模板,然后再开始注入

image-20240916213649098

当完成注入后,结果页面 default.html 效果如下

image-20240916214007155

渲染成表格或者图表

此时,我们便得到了有个 resultList数组了,最后根据自己需求完成渲染的效果即可

一键启动

为了方便在本地直接运行程序得到结果。我们需要加入以下手段

  1. 双击打开脚本自动运行程序
  2. 自动调用浏览器打开页面

双击打开脚本自动运行程序

  1. 新建 start.bat 文件,加入以下内容

    node index.js
    
  2. 后续 直接双击该文件即可

image-20240916214542002

自动调用浏览器打开页面

利用 child_processexec 方法,便可直接在程序中启动指定页面

引入

const template = fs.readFileSync("./index.html", "utf8")

启动

exec(`start ./default.html`)

项目目录结构

image-20240916214605522

后续

如果想要直接发布到网上,通过一个简单的网址便可以实现以上功能,可以考虑uniapp中提供的云函数和静态托管功能,几乎没有成本便可以使用。但是需要进行简单的改造,如果有想要了解的小朋友可以在文章下留言,我可以抽空整理下这个迁移步骤

总结

基于以上功能,我们便可以知道小伙伴的工作程度了

image-20240916214945248

祝福

八月十四星河动, 银河未渡鹊桥空。 程序世界码飞舞, 牛马勤耕夜不终。

荧屏闪亮寻BUG, 键盘轻敲创无双。 牛马诸君皆英杰, 巧手编译梦飞扬。

愿君代码皆顺遂, 逻辑清晰少冗长。 七夕虽近情未了, 心意遥寄网络上。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2141070.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

高德2.0 多边形覆盖物无法选中编辑

多边形覆盖物无法选中编辑。先检查一下数据的类型得是<number[]>,里面是字符串的虽然显示没问题&#xff0c;但是不能选中编辑。 &#xff08;在项目中排查了加载时机&#xff0c;事件监听…等等种种原因&#xff0c;就是没发现问题。突然想到可能是数据就有问题&#xf…

ROS组合导航笔记:融合传感器数据

使用机器人定位包&#xff08;robot_localization package&#xff09;来合并来自不同传感器的数据&#xff0c;以改进机器人定位时的姿态估计。 基本概念 在现实生活中操作机器人时&#xff0c;有时我们需要处理不够准确的传感器数据。如果我们想要实现机器人的高精度定位&am…

初探全同态加密1 —— FHE的定义与历史回顾

文章目录 一、加密体系1、什么是加密体系2、加密体系的属性 Properties 二、同态加密&#xff1a;偶然的特殊性质三、同态加密体系的分类四、部分同态加密 Partially Homomorphic Encryption1、加法同态加密算法 —— ElGamal 加密算法1.1、ElGamal 的大致步骤1.2、ElGamal 的加…

vue3+vite项目中使用阿里图标库(svg)图标

前端项目中有很多地方会用到小图标&#xff0c;阿里的 iconfont 是一个不错的选择&#xff0c;同时&#xff0c; 它上面的 svg 矢量图标占用资源更少加载更快是一个不错的选择&#xff0c; 下面我们就来说一说&#xff0c;项目中如何来使用 svg 图标 安装插件 vite-plugin-svg…

RP2040 C SDK SysTick滴答定时器功能使用

RP2040 C SDK SysTick滴答定时器功能使用 ✨更好的阅读体验请移步到&#xff1a;飞书-云文档&#xff1a;https://u1etqmuwl9z.feishu.cn/wiki/VkoHwPGqHierOEkY651cZvaOntg?fromfrom_copylink RP2040的SysTick滴答定时器为24位的&#xff0c;计数方式为倒计时&#xff0c;扩展…

基于对数变换的图像美白增强,Matlab实现

博主简介&#xff1a;matlab图像处理&#xff08;QQ:3249726188&#xff09; ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 本次案例是基于对数变换的图像美白增强&#xff0c;用matlab实现。 一、案例背景和算法介绍 这次案例是美白算法&…

Stable Diffusion Web UI基础插件推荐

通过前面知识的介绍&#xff0c;我们对使用 Web UI 进行绘画有了基本了解&#xff0c;在平时我们使用中&#xff0c;有很多好用的插件&#xff0c;通过这些插件我们创作能够事半功倍&#xff0c;下面我就推荐一下在平时经常使用到的插件&#xff0c;希望这篇文章能够帮助大家更…

MelosBoom:解锁数据价值的新纪元

在当今的数字时代&#xff0c;数据被誉为“新的石油”&#xff0c;但用户在传统的Web2环境中&#xff0c;往往无法真正享受到自己贡献数据的价值。大型互联网公司通过集中化的系统和算法&#xff0c;垄断了数据的使用权&#xff0c;并从中获取巨大的商业利益&#xff0c;而数据…

浏览器页面被禁用 F12(dev tools)

解决办法1: 使用浏览器设置栏, 打开开发者工具, 设置->更多工具->开发者工具 解决办法2: 命令行启动浏览器, 携带参数, 强制打开所有页面的 devtools chrome.exe –auto-open-devtools-for-tabs –user-data-dir./

时序必读论文10|ICLR23 Crossformer 跨维度依赖的多变量时序预测模型

论文标题&#xff1a;iCROSSFORMER : TRANSFORMER UTILIZING CROSS DIMENSION DEPENDENCY FOR MULTIVARIATE TIME SERIES FORECASTING 开源代码&#xff1a;https://github.com/Thinklab-SJTU/Crossformer 前言 Crossformer是一篇非常典型的在transformer基础上魔改注意力机…

k8s使用本地docker私服启动自制的flink集群

目标&#xff1a;使用本地flink环境自制flink镜像包上传到本地的私服&#xff0c;然后k8s使用本地的私服拉取镜像启动Flink集群 1、将本地的flink软件包打包成Docker镜像 从官网下载flink-1.13.6的安装包&#xff0c;修改其中的flink-conf.yaml&#xff0c;修改下面几项配置 …

鸿蒙开发之ArkTS 基础九 枚举类型

枚举把变量固定在特定的范围内 枚举的语法&#xff1a; enum 枚举名字 { 常量1 值1, 常量1 值1, 常量1 值1, ... } 定义具体如下: 使用具体如下&#xff1a;

【无人机设计与控制】四旋翼无人机俯仰姿态保持模糊PID控制(带说明报告)

摘要 为了克服常规PID控制方法在无人机俯仰姿态控制中的不足&#xff0c;本研究设计了一种基于模糊自适应PID控制的控制律。通过引入模糊控制器&#xff0c;实现了对输入输出论域的优化选择&#xff0c;同时解决了模糊规则数量与控制精度之间的矛盾。仿真结果表明&#xff0c;…

【探索数据结构与算法】希尔排序原理、实现与分析(图文详解)

目录 一、 引言 二、算法思想 三、算法步骤 四、代码实现 五、复杂度 &#x1f493; 博客主页&#xff1a;C-SDN花园GGbond ⏩ 文章专栏&#xff1a;探索数据结构与算法 一、 引言 希尔排序&#xff08;Shell Sort&#xff09;是插入排序的一种更高效的改进版本&#x…

vulnhub靶机:Skytower

下载 下载地址&#xff1a;https://www.vulnhub.com/entry/skytower-1,96/ 导入靶机 解压发现是VirtualBox格式的&#xff0c;下载一个VirtualBox&#xff1a;Downloads – Oracle VirtualBox 选择解压后的vbox文件&#xff0c;然后点击左上角管理 点击导出虚拟电脑&#xff…

Datawhale------Tiny-universe学习笔记——Qwen

1. Qwen整体介绍 对于一个完全没接触过大模型的小白来说&#xff0c;猛一听这个名字首先会一懵&#xff1a;Qwen是啥。这里首先解答一下这个问题。下面是官网给出介绍&#xff1a;Qwen是阿里巴巴集团Qwen团队研发的大语言模型和大型多模态模型系列。其实随着大模型领域的发展&a…

卡尔曼滤波中Q和R与噪声的关系

卡尔曼滤波 一种用于估计系统状态的递归滤波器&#xff0c;通过融合传感器测量和系统模型&#xff0c;提供系统状态的最优估计。 Q和R是什么 在卡尔曼滤波中&#xff0c;Q和R分别表示过程噪声和测量噪声的协方差矩阵。 Q Q Q矩阵&#xff08;过程噪声协方差矩阵&#xff09;…

电子连接器温升仿真教程 一

电子连接器温升是指电子连接器的所有端子在施加额定电载荷的情况下,经过一段时间后,达成热平衡,连接器局部温度不再继续升高,此时规定测试点的温度与测试环境温度的差值。连接器的温升规格值因其应用环境不同,而不同。工业应用,且不与人体接触的电子连接器一般允许温升会…

日系编曲:电吉他音色制作 拾音器选择 电吉他音色制作逻辑 音箱分类 效果器单块分类

拾音器选择 拾音器&#xff1a;获取琴弦震动产生电信号经过线材传输到音箱&#xff08;amp&#xff09;使听众听到 一般的电吉他分为三块和两块拾音器&#xff0c;挡位分为三档或五档 Bridge&#xff08;琴桥拾音器&#xff09;&#xff1a;声音更加清晰&#xff0c;音色更突…

[JAVA]介绍怎样在Java中通过字节字符流实现文件读取与写入

一&#xff0c;初识File类及其常用方法 File类是java.io包下代表与平台无关的文件和目录&#xff0c;程序中操作文件和目录&#xff0c;都可以通过File类来完成。 通过这个File对象&#xff0c;可以进行一系列与文件相关的操作&#xff0c;比如判断文件是否存在&#xff0c;获…