从针尖对麦芒,到丝滑入扣,记录那些BT需求
前言:
最近被一个“简单”的需求,搞的有点难受。需求其实很简单,就是记录某成品生产过程数据,然后进行展示,但因需求部门是管理部门。为了能获取足够多的参数来提高生产效率和研发进度。因此需要生产来统计收集对应生产过程的参数,如收集某个反应单号、反应釜对应是什么时候开始的,开始的时候对应反应的参数,如温度、PH、电流、搅拌频率、氨浓度、粒度等等,不下40多个检测项目,因此可想而知这个收集表是又臭又长。因此最后的成品大概长这样。

从图片可以看出后面还有很多很多参数没显示出来。
一、针尖对麦芒
1、会议讨论猛如虎,剩下只有能不能
从上面的图片我们可想而知,管理部门在推动生产去做录入应用的时候,生产主任肯定会抱怨,录入的内容太多了,数据能不能自动带出来、能不能防呆、等等。因此在第一次试运行会议上,就出现了针尖对麦芒对麦芒的场景。最后一顿群枪舌剑后,提出了3年都改不完的需求到了我们这边。哈哈哈哈,真是鹬蚌相争,IT“得利"。

最后主要提出的需求点是:
1、日期能不能自动带出来,时间能不能自动累计变化,反应时长能不能自动变?
2、能不能像EXCEL那样直接拉一下数据就跟着变?
3、能不能根据我录入时间自动变化日期?有些值是固定的,能不能自动填充?
4、能不能通过EXCEL一次性把数据导入进去?
5、能不能做数据录入校验,比如录数据的地方不能录字符?
6、能不能设置必填项,重要信息比较完整?
7、能不能规定录入的内容,比如只能录入“是”或者“否”的地方,不能录入其他的,比如是加一个空格?
8、能不能.......?
2、能不能?不能?那得能
2.1、内心的emo
哈哈哈,上面的一顿能不能实在是把我问麻了?我整个人都emo了。从刚开始的激情分析,到后面的可以,我想想办法,最后我甚至都懒得动嘴了。然后他们看我不回答了,旁边的小伙伴直接来一句先记下来,我们回去研究研究。我心里真的是想谢谢你呢。
其实这一切的罪恶之源,就是数字化建设需要一个较长的过程,但是业务部门在建设时期,需要开展业务,也想提高效率,因此想先手工录入数据,将业务先固化下来,把标准规则做起来,至少数据线上化了,共享了,不在会出现N个版本的数据,也不需要跨部门催数据。总的来说是好的。因此对于IT人员来说,确实能体现我们的价值,加上IT人员都是热心肠,那不就是能,太能了啊!哈哈哈哈,那看看都是怎么实现的吧。
2.2、一点小思路
因为提的需求实在太多,这边就挑几个典型的说下实现思路。
因为不同工序的录入人员不愿意统一在一个大表录入,因此我们将最开始的那张大表拆分成了三张小表,如下图所示,小试、中试、量试。

如我们将小试拆分成了这样,默认我们就会带出反应级别为小试,默认带出当天的日期。默认未录入数据的时候不能进行删除操作等等。

为了保证数据质量,通过设置必填提示,并颜色标记必填项提醒用户哪些是必填的,等等。

二、有点AI的东西
其实受最近AI的影响,导致下面40 50岁的大爷,天天刷短视频,说这个能不能自动带出来,那个能不能自动计算,能不能自动查重。。。等等,主打的就是一个自动,主打的就是一个解放双手。针对前面提到的 "日期能不能自动带出来,时间能不能自动累计变化,反应时长能不能自动变?",来聊聊这个有点AI的东西。
1、AI进化论
首先看这个日期自动带出,就存在一个BT的点,就是用户在录入数据的时候,自动带出当天的日期,超过12点带出第二天的日期,这个需求还是比较简单实现,默认为空的时候赋值为today()的函数来获取系统日期。但是有个BT的点就是,当用户在录入某个日期23点的数据后,再点击新增就需要变化至第二天日期,并变化时间。因为需设置时间是24小时制。而且需要进位加1天的日期。针对这个需求你觉得应该怎么实现呢?
我们先看效果

效果图
如上图所示,当我们选择时间为00:57后点插入行,自动变化为01:57,并且反应时长自动累加。
当然班次是根据时间自动判断的,0点到8点半是早班,8点半到17点是中班,其他是晚班。当然这些都比较简单,复杂的是时间自动跳的时候超过23点的时候,自动回0并且日期加1天。因此我们通过截取选择时间的:左边的小时,或者对应的小时,点插入行的时候,自动将小时加1,然后再判断时间时候小于10小时,小于10时,前面填充个0变成01 02 03 。。09。然后再和后面的分钟拼接起来。 这样基本就实现了自动跳小时加1。最后通过mod(小时,24)自动让小时从0到23变化。其实这时候的日期变化就变的简单,只要上一行的小时变化成23的时候,自动将日期+1即可。
具体的动态效果我们可以看下视频
20230816_225117
2、进化论2.0
细心的小伙伴,可能会发现,插入行的时候因为是根据上一行的值来自动填充下一行的值,因此,如果我们点击的不是最后一行就会导致填充的数据错误,因此用户就开始emo了。

因此用户需要一个自动能填充多行,而且不用担心填充错误的功能,说实话,我也是第一次遇到这么BT的需求,因此苦苦研究了下,想到了一个数据定位功能,让功能按钮每次都能定位到最后一行,此时再点击插入就不会导致数据插入错误,只要无脑点击就行,当然了有插入必然会因为插入点的比较嗨,导致插入的多了,因此也需要一个无脑可以删除的功能,只需要点击删除就可以删除最后一行。因此最后通过JS来判断数据位置,每次从最后一行 进行数据的插入和删除就实现了这个需求。最后这个功能界面长这样。
定位插入行位置,每次自动定位,删除/插入最后一行
三、你以为这就结束了?
经过,多次迭代终于将上面提的需求完成了,但是万万没想到出现了一个emo需求,因为上下是两个表,因此数据存在两个表中,为了防止数据被误删除了,因此数据都是没有被真正删除,而是通过一个删除标记来记录是否删除,比如当删除标记dr=0时表示未删除,dr=1就表示删除。因为没考虑到他们会对删除的数据做修改或者二次录入因此,最后出现了一个这样的场景,上面主表是没数据,当明细表时有数据的,我们称之为无头勇士。真的是笑喷了,这也为我无尽的需求增添了一丝丝慰藉,哈哈哈,真是愉快的一天啊~

相关文章:
从针尖对麦芒,到丝滑入扣,记录那些BT需求
前言: 最近被一个“简单”的需求,搞的有点难受。需求其实很简单,就是记录某成品生产过程数据,然后进行展示,但因需求部门是管理部门。为了能获取足够多的参数来提高生产效率和研发进度。因此需要生产来统计收集对应生产…...
封装vue2局部组件都要注意什么
一. 关于局部组件组成的三个部分(template, script, style) template > 组件的模板结构 (必选) 每个组件对应的模板结构,需要定义到template节点中 <template><!-- 当前组件的dom结构,需…...
【深入浅出程序设计竞赛(基础篇)第三章 算法从0开始】
深入浅出程序设计竞赛(基础篇)第三章 算法从0开始 第三章 例题例3-1例3-2例3-3例3-4例3-5例3-6例3-7例3-8例3-9例3-10例3-11例3-12 第三章 课后习题3-13-23-33-43-53-63-73-83-9 第三章 例题 例3-1 #include<iostream> using namespace std;int …...
安全之安全(security²)博客目录导读
研究方向:安全之安全 研究内容:ARM/RISC-V安全架构、TF-A/TEE之安全、GP安全认证、静态代码分析、FUZZ模糊测试、IDA逆向分析、安全与功耗等,欢迎您的关注💖💖 一、ARM安全架构 1、ARM安全架构及其发展趋势࿰…...
ubuntu安装opencv4
apt 安装 sudo apt install libopencv-dev python3-opencvpkg-config查看安装 sudo apt install pkg-configpkg-config --modversion opencv4pkg-config --libs --cflags opencv4参考 如何在 Ubuntu 20.04 上安装 OpenCV pkg-config 详解...
Qt 当磁盘可用空间小于指定大小时删除早期的文件
1. 需求 用户反应,电脑由于自身磁盘空间只有128G,由于软件执行一次任务,就要录视频记录,导致磁盘空间爆满,电脑卡,无法再次生成视频 2. 分析:当时软件没有写自动删除视频的代码导致的。 可以…...
浙大数据结构第七周之07-图6 旅游规划
题目详情: 有了一张自驾旅游路线图,你会知道城市间的高速公路长度、以及该公路要收取的过路费。现在需要你写一个程序,帮助前来咨询的游客找一条出发地和目的地之间的最短路径。如果有若干条路径都是最短的,那么需要输出最便宜的…...
RocketMQ双主双从同步集群部署
🎈 作者:互联网-小啊宇 🎈 简介: CSDN 运维领域创作者、阿里云专家博主。目前从事 Kubernetes运维相关工作,擅长Linux系统运维、开源监控软件维护、Kubernetes容器技术、CI/CD持续集成、自动化运维、开源软件部署维护…...
分类预测 | MATLAB实现EVO-CNN多输入分类预测
分类预测 | MATLAB实现EVO-CNN多输入分类预测 目录 分类预测 | MATLAB实现EVO-CNN多输入分类预测预测效果基本介绍程序设计参考资料 预测效果 基本介绍 1.MATLAB实现EVO-CNN多输入分类预测 2.代码说明:量谷优化卷积神经网络的数据分类预测:要求于Matlab …...
DAY04_SpringMVC—SpringMVC简介PostMan和ApiFox工具使用SpringMVC请求与响应REST风格
目录 一 SpringMVC简介1 SpringMVC概述问题导入1.1 SpringMVC概述 2 入门案例问题导入2.0 回顾Servlet技术开发web程序流程2.1 使用SpringMVC技术开发web程序流程2.2 代码实现【第一步】创建web工程(Maven结构)【第二步】设置tomcat服务器,加…...
phpstorm配置ftp同步文件到服务器
这里的默认快捷键 不是 CtrlS ;需要设置快捷键,这里原来是save all操作时上传文件到服务器; ** 设置好快捷键后按 CtrlS就会同步文件(添加删除文件后保存,服务器也会同步) ** 搜索出save all 后…...
前端jd要求:了解一门后端开发语言优先 解决方案之Node.js
前端jd要求:了解一门后端开发语言优先 解决方案之Node.js 前言常见的后端开发语言一、什么是 Node.js二、学习 Node.js 的前置知识三、学习 Node.js 的步骤1、Node.js 的安装2、Node.js 的基本语法和 API模块导入和导出文件读写操作HTTP 服务器命令行参数 3、Node.j…...
什么是ServiceMesh(Istio一)
现在最火的后端架构无疑是微服务了,微服务将之前的单体应用拆分成了许多独立的服务应用,每个微服务都是独立的,好处自然很多,但是随着应用的越来越大,微服务暴露出来的问题也就随之而来了,微服务越来越多&a…...
【腾讯云 Cloud Studio 实战训练营】Hexo 框架 Butterfly 主题搭建个人博客
什么是Cloud Studio Cloud Studio 是基于浏览器的集成式开发环境(IDE),为开发者提供了一个永不间断的云端工作站。用户在使用 Cloud Studio 时无需安装,随时随地打开浏览器就能在线编程。 Hexo 博客成品展示 本人博客如下&…...
搭建Excel服务器
1、下载Excel服务器 下载地址 2、解压文件 3、打开服务器 4、服务器运行信息 5、连接测试 打开客户端 6、登录到服务器 默认账号 密码 admin 3 修改文件保存路径(服务器端点击配置) 7、客户端整体界面 8、配置权限 9、设计模板 10、其他用户登录就可以填写信息 11、用户&#…...
渗透测试成功的8个关键
渗透测试 (penetration test)并没有一个标准的定义,国外一些安全组织达成共识的通用说法是:渗透测试是通过模拟恶意黑客的攻击方法,来评估计算机网络系统安全的一种评估方法。这个过程包括对系统的任何弱点、技术缺陷或漏洞的主动分析&#x…...
【leetcode】链表part2
24. 两两交换链表中的节点 迭代方法 public static ListNode swapPairs(ListNode head) {// 输入:head [1,2,3,4]// 输出:[2,1,4,3]ListNode dummy new ListNode(0);dummy.next head;ListNode cur dummy;while (cur.next ! null && cur.ne…...
C#数据类型转换
目录 1.常用的数据类型: 编辑1.1别名概念例子: 输出结果: 2.数值类型之间的相互转换: 2.1举例: 编辑输出结果: 1.常用的数据类型: 1.1别名概念例子: 输出结果: 用GetType来获取数据类型的时候,就是指向System.Byte和System.Char这个…...
mybatis-plus逻辑删除的坑
一旦在逻辑字段上加了TableLogic逻辑删除的配置,并且使用mybatis-plus自带的方法时(如果自己用xml写SQL不会出现下面的情况) 查询、修改时会自动排除逻辑删除的数据 当使用mybatis-plus自带的查询方法时,就不用每次查询的时候跟…...
SQL Server基础之游标
一:认识游标 游标是SQL Server的一种数据访问机制,它允许用户访问单独的数据行。用户可以对每一行进行单独的处理,从而降低系统开销和潜在的阻隔情况,用户也可以使用这些数据生成的SQL代码并立即执行或输出。 1.游标的概念 游标是…...
基于uniapp+WebSocket实现聊天对话、消息监听、消息推送、聊天室等功能,多端兼容
基于 UniApp + WebSocket实现多端兼容的实时通讯系统,涵盖WebSocket连接建立、消息收发机制、多端兼容性配置、消息实时监听等功能,适配微信小程序、H5、Android、iOS等终端 目录 技术选型分析WebSocket协议优势UniApp跨平台特性WebSocket 基础实现连接管理消息收发连接…...
Swift 协议扩展精进之路:解决 CoreData 托管实体子类的类型不匹配问题(下)
概述 在 Swift 开发语言中,各位秃头小码农们可以充分利用语法本身所带来的便利去劈荆斩棘。我们还可以恣意利用泛型、协议关联类型和协议扩展来进一步简化和优化我们复杂的代码需求。 不过,在涉及到多个子类派生于基类进行多态模拟的场景下,…...
可靠性+灵活性:电力载波技术在楼宇自控中的核心价值
可靠性灵活性:电力载波技术在楼宇自控中的核心价值 在智能楼宇的自动化控制中,电力载波技术(PLC)凭借其独特的优势,正成为构建高效、稳定、灵活系统的核心解决方案。它利用现有电力线路传输数据,无需额外布…...
Auto-Coder使用GPT-4o完成:在用TabPFN这个模型构建一个预测未来3天涨跌的分类任务
通过akshare库,获取股票数据,并生成TabPFN这个模型 可以识别、处理的格式,写一个完整的预处理示例,并构建一个预测未来 3 天股价涨跌的分类任务 用TabPFN这个模型构建一个预测未来 3 天股价涨跌的分类任务,进行预测并输…...
学校招生小程序源码介绍
基于ThinkPHPFastAdminUniApp开发的学校招生小程序源码,专为学校招生场景量身打造,功能实用且操作便捷。 从技术架构来看,ThinkPHP提供稳定可靠的后台服务,FastAdmin加速开发流程,UniApp则保障小程序在多端有良好的兼…...
质量体系的重要
质量体系是为确保产品、服务或过程质量满足规定要求,由相互关联的要素构成的有机整体。其核心内容可归纳为以下五个方面: 🏛️ 一、组织架构与职责 质量体系明确组织内各部门、岗位的职责与权限,形成层级清晰的管理网络…...
在WSL2的Ubuntu镜像中安装Docker
Docker官网链接: https://docs.docker.com/engine/install/ubuntu/ 1、运行以下命令卸载所有冲突的软件包: for pkg in docker.io docker-doc docker-compose docker-compose-v2 podman-docker containerd runc; do sudo apt-get remove $pkg; done2、设置Docker…...
关键领域软件测试的突围之路:如何破解安全与效率的平衡难题
在数字化浪潮席卷全球的今天,软件系统已成为国家关键领域的核心战斗力。不同于普通商业软件,这些承载着国家安全使命的软件系统面临着前所未有的质量挑战——如何在确保绝对安全的前提下,实现高效测试与快速迭代?这一命题正考验着…...
论文笔记——相干体技术在裂缝预测中的应用研究
目录 相关地震知识补充地震数据的认识地震几何属性 相干体算法定义基本原理第一代相干体技术:基于互相关的相干体技术(Correlation)第二代相干体技术:基于相似的相干体技术(Semblance)基于多道相似的相干体…...
音视频——I2S 协议详解
I2S 协议详解 I2S (Inter-IC Sound) 协议是一种串行总线协议,专门用于在数字音频设备之间传输数字音频数据。它由飞利浦(Philips)公司开发,以其简单、高效和广泛的兼容性而闻名。 1. 信号线 I2S 协议通常使用三根或四根信号线&a…...
