c#窗体应用程序实现当软件开启,定时器就在数据库扫描是否有设置的良品和不良品条码的当天ICT测试记录(ICT_test表中Barcode,Date,Result),良品和不良品条码在本地文件夹txt文件中获取。如果数据库中有良品和不良品测试记录存在,lable状态栏变绿并提示“已点检,请进行测试”,然后进行别的条码的ICT测试。(条码先扫描到c#窗体软件txt_barcode中,在通过模拟键盘定位发送到ICT测试软件条码框中,然后进行ICT测试)。如果没有,label状态栏变红,并提示“请进行测试前点检”,然后就先进行设置条码的ICT测试,判断扫描到txt_Barcode条码是否为获取到设置的良品或不良品条码,如输入的条码不符合,label状态栏变红,并提示“条码错误”,如输入的条码正确并为设置的良品条码,label状态栏变绿,并提示“请进行良品点检”,进行ICT测试,当发现某一文件夹中有良品测试报告生成,表示良品测试完成,测试完成后就提示“良品点检完成”。如扫描的是设置的不良品条码,则label状态栏变绿,并提示“请进行不良品点检”,进行ICT测试。当发现某一文件夹中有不良品测试报告生成,表示不良品测试完成。当这设置的两个条码都测试完成后,将测试记录直接更新到数据库,不需要点击上传c#代码实现.

时间: 2023-11-25 10:04:49 浏览: 31
以下是一个简单的实现方式,可以参考: 1. 在窗体的Load事件中,启动定时器,并设置其Tick事件的处理方法为ScanDatabase。 2. 在ScanDatabase方法中,使用SQL语句从数据库中查询设置的良品和不良品条码当天的测试记录,如果存在,则更新状态栏Label的文本为“已点检,请进行测试”,并将isReady字段设为true;否则更新状态栏Label的文本为“请进行测试前点检”,并将isReady字段设为false。 3. 在扫描到txt_Barcode条码时,判断isReady字段的值,如果为true,则判断扫描到的条码是否为设置的良品或不良品条码,如果是,则将状态栏Label的文本更新为“请进行良品点检”或“请进行不良品点检”,并进行ICT测试;否则将状态栏Label的文本更新为“条码错误”。 4. 在良品或不良品点检完成后,检查相应的测试报告文件夹是否存在测试报告文件,如果存在,则将测试记录更新到数据库,并将状态栏Label的文本更新为“良品点检完成”或“不良品点检完成”。 5. 在窗体关闭时,停止定时器。 下面是示例代码: ```csharp public partial class MainForm : Form { private bool isReady = false; // 是否可以进行测试 public MainForm() { InitializeComponent(); } private void MainForm_Load(object sender, EventArgs e) { // 启动定时器,每5秒扫描一次数据库 timer1.Interval = 5000; timer1.Tick += new EventHandler(ScanDatabase); timer1.Start(); } private void MainForm_FormClosing(object sender, FormClosingEventArgs e) { // 关闭窗体时停止定时器 timer1.Stop(); } private void ScanDatabase(object sender, EventArgs e) { string today = DateTime.Today.ToString("yyyy-MM-dd"); string sql = "SELECT * FROM ICT_test WHERE Date='" + today + "' AND (Barcode='" + txt良品条码.Text + "' OR Barcode='" + txt不良品条码.Text + "')"; DataTable dt = ExecuteQuery(sql); if (dt.Rows.Count > 0) { // 数据库中有设置的良品或不良品当天测试记录 lblStatus.ForeColor = Color.Green; lblStatus.Text = "已点检,请进行测试"; isReady = true; } else { // 数据库中没有设置的当天测试记录 lblStatus.ForeColor = Color.Red; lblStatus.Text = "请进行测试前点检"; isReady = false; } } private void txtBarcode_KeyDown(object sender, KeyEventArgs e) { if (e.KeyCode == Keys.Enter) { string barcode = txtBarcode.Text.Trim(); if (isReady) { if (barcode == txt良品条码.Text) { lblStatus.ForeColor = Color.Green; lblStatus.Text = "请进行良品点检"; DoICTTest(barcode); } else if (barcode == txt不良品条码.Text) { lblStatus.ForeColor = Color.Green; lblStatus.Text = "请进行不良品点检"; DoICTTest(barcode); } else { lblStatus.ForeColor = Color.Red; lblStatus.Text = "条码错误"; } } else { lblStatus.ForeColor = Color.Red; lblStatus.Text = "请进行测试前点检"; } } } private void DoICTTest(string barcode) { // 发送条码到ICT测试软件 SendBarcodeToICT(barcode); // 等待测试完成,检查测试报告文件夹 string reportFolder = GetReportFolder(barcode); while (!File.Exists(reportFolder + "\\" + barcode + ".txt")) { Thread.Sleep(1000); } // 更新测试记录到数据库 string today = DateTime.Today.ToString("yyyy-MM-dd"); string result = GetTestResult(barcode); string sql = "UPDATE ICT_test SET Result='" + result + "' WHERE Date='" + today + "' AND Barcode='" + barcode + "'"; ExecuteNonQuery(sql); // 更新状态栏 if (barcode == txt良品条码.Text) { lblStatus.Text = "良品点检完成"; } else { lblStatus.Text = "不良品点检完成"; } } private DataTable ExecuteQuery(string sql) { // 执行SQL查询语句,返回查询结果 string connectionString = "Data Source=myServerAddress;Initial Catalog=myDataBase;User ID=myUsername;Password=myPassword"; SqlConnection connection = new SqlConnection(connectionString); SqlDataAdapter dataAdapter = new SqlDataAdapter(sql, connection); DataTable dataTable = new DataTable(); dataAdapter.Fill(dataTable); return dataTable; } private void ExecuteNonQuery(string sql) { // 执行SQL非查询语句,如UPDATE、INSERT、DELETE等 string connectionString = "Data Source=myServerAddress;Initial Catalog=myDataBase;User ID=myUsername;Password=myPassword"; SqlConnection connection = new SqlConnection(connectionString); SqlCommand command = new SqlCommand(sql, connection); connection.Open(); command.ExecuteNonQuery(); connection.Close(); } private void SendBarcodeToICT(string barcode) { // 将条码发送到ICT测试软件 // TODO: 实现发送逻辑 } private string GetReportFolder(string barcode) { // 根据条码获取对应的测试报告文件夹路径 // TODO: 实现获取逻辑 } private string GetTestResult(string barcode) { // 根据条码获取对应的测试结果,如PASS或FAIL // TODO: 实现获取逻辑 } } ```

相关推荐

最新推荐

recommend-type

基于网络的入侵检测系统源码+数据集+详细文档(高分毕业设计).zip

基于网络的入侵检测系统源码+数据集+详细文档(高分毕业设计).zip个人经导师指导并认可通过的高分毕业设计项目,评审分98分。主要针对计算机相关专业的正在做毕设的学生和需要项目实战练习的学习者,也可作为课程设计、期末大作业。 基于网络的入侵检测系统源码+数据集+详细文档(高分毕业设计).zip基于网络的入侵检测系统源码+数据集+详细文档(高分毕业设计).zip基于网络的入侵检测系统源码+数据集+详细文档(高分毕业设计).zip基于网络的入侵检测系统源码+数据集+详细文档(高分毕业设计).zip基于网络的入侵检测系统源码+数据集+详细文档(高分毕业设计).zip基于网络的入侵检测系统源码+数据集+详细文档(高分毕业设计).zip基于网络的入侵检测系统源码+数据集+详细文档(高分毕业设计).zip基于网络的入侵检测系统源码+数据集+详细文档(高分毕业设计).zip基于网络的入侵检测系统源码+数据集+详细文档(高分毕业设计).zip基于网络的入侵检测系统源码+数据集+详细文档(高分毕业设计).zip基于网络的入侵检测系统源码+数据集+详细文档(高分毕业设计).zip基于网络的入侵检测系统
recommend-type

本户型为2层独栋别墅D026-两层-13.14&12.84米-施工图.dwg

本户型为2层独栋别墅,建筑面积239平方米,占地面积155平米;一层建筑面积155平方米,设有客厅、餐厅、厨房、卧室3间、卫生间1间、杂物间;二层建筑面积84平方米,设有卧室2间、卫生间1间、储藏间、1个大露台。 本户型外观造型别致大方,采光通风良好,色彩明快,整体平面布局紧凑、功能分区合理,房间尺度设计适宜,豪华大气,富有时代气息。
recommend-type

Java_带有可选web的开源命令行RatioMaster.zip

Java_带有可选web的开源命令行RatioMaster
recommend-type

基于MATLAB实现的OFDM经典同步算法之一Park算法仿真,附带Park算法经典文献+代码文档+使用说明文档.rar

CSDN IT狂飙上传的代码均可运行,功能ok的情况下才上传的,直接替换数据即可使用,小白也能轻松上手 【资源说明】 基于MATLAB实现的OFDM经典同步算法之一Park算法仿真,附带Park算法经典文献+代码文档+使用说明文档.rar 1、代码压缩包内容 主函数:main.m; 调用函数:其他m文件;无需运行 运行结果效果图; 2、代码运行版本 Matlab 2020b;若运行有误,根据提示GPT修改;若不会,私信博主(问题描述要详细); 3、运行操作步骤 步骤一:将所有文件放到Matlab的当前文件夹中; 步骤二:双击打开main.m文件; 步骤三:点击运行,等程序运行完得到结果; 4、仿真咨询 如需其他服务,可后台私信博主; 4.1 期刊或参考文献复现 4.2 Matlab程序定制 4.3 科研合作 功率谱估计: 故障诊断分析: 雷达通信:雷达LFM、MIMO、成像、定位、干扰、检测、信号分析、脉冲压缩 滤波估计:SOC估计 目标定位:WSN定位、滤波跟踪、目标定位 生物电信号:肌电信号EMG、脑电信号EEG、心电信号ECG 通信系统:DOA估计、编码译码、变分模态分解、管道泄漏、滤波器、数字信号处理+传输+分析+去噪、数字信号调制、误码率、信号估计、DTMF、信号检测识别融合、LEACH协议、信号检测、水声通信 5、欢迎下载,沟通交流,互相学习,共同进步!
recommend-type

基于MATLAB实现的对机械振动信号用三维能量谱进行分析+使用说明文档.rar

CSDN IT狂飙上传的代码均可运行,功能ok的情况下才上传的,直接替换数据即可使用,小白也能轻松上手 【资源说明】 基于MATLAB实现的对机械振动信号用三维能量谱进行分析+使用说明文档.rar 1、代码压缩包内容 主函数:main.m; 调用函数:其他m文件;无需运行 运行结果效果图; 2、代码运行版本 Matlab 2020b;若运行有误,根据提示GPT修改;若不会,私信博主(问题描述要详细); 3、运行操作步骤 步骤一:将所有文件放到Matlab的当前文件夹中; 步骤二:双击打开main.m文件; 步骤三:点击运行,等程序运行完得到结果; 4、仿真咨询 如需其他服务,可后台私信博主; 4.1 期刊或参考文献复现 4.2 Matlab程序定制 4.3 科研合作 功率谱估计: 故障诊断分析: 雷达通信:雷达LFM、MIMO、成像、定位、干扰、检测、信号分析、脉冲压缩 滤波估计:SOC估计 目标定位:WSN定位、滤波跟踪、目标定位 生物电信号:肌电信号EMG、脑电信号EEG、心电信号ECG 通信系统:DOA估计、编码译码、变分模态分解、管道泄漏、滤波器、数字信号处理+传输+分析+去噪、数字信号调制、误码率、信号估计、DTMF、信号检测识别融合、LEACH协议、信号检测、水声通信 5、欢迎下载,沟通交流,互相学习,共同进步!
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

【实战演练】MATLAB用遗传算法改进粒子群GA-PSO算法

![MATLAB智能算法合集](https://static.fuxi.netease.com/fuxi-official/web/20221101/83f465753fd49c41536a5640367d4340.jpg) # 2.1 遗传算法的原理和实现 遗传算法(GA)是一种受生物进化过程启发的优化算法。它通过模拟自然选择和遗传机制来搜索最优解。 **2.1.1 遗传算法的编码和解码** 编码是将问题空间中的解表示为二进制字符串或其他数据结构的过程。解码是将编码的解转换为问题空间中的实际解的过程。常见的编码方法包括二进制编码、实数编码和树形编码。 **2.1.2 遗传算法的交叉和
recommend-type

openstack的20种接口有哪些

以下是OpenStack的20种API接口: 1. Identity (Keystone) API 2. Compute (Nova) API 3. Networking (Neutron) API 4. Block Storage (Cinder) API 5. Object Storage (Swift) API 6. Image (Glance) API 7. Telemetry (Ceilometer) API 8. Orchestration (Heat) API 9. Database (Trove) API 10. Bare Metal (Ironic) API 11. DNS
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。