C#根据数据量自动排版标签的样例

在这里插入图片描述
这是一个C#根据数据量自动排版标签的样例

using System;
using System.Collections.Generic;
using System.Data.SqlClient;
using System.Drawing;
using System.Text;
using System.Threading;
using System.Threading.Tasks;
using System.Windows.Forms;
using HslCommunication.Profinet;namespace WindowsFormsApp1
{public partial class Form1 : Form{private CancellationTokenSource _cancellationTokenSource;private Dictionary<string, string> fieldMappings;public Form1(){InitializeComponent();InitializeFieldMappings();}private void Form1_Load(object sender, EventArgs e){}private void InitializeFieldMappings(){fieldMappings = new Dictionary<string, string>{{ "pltid", "平台ID" },{ "basketcode", "篮子编码" },{ "code", "编码" },{ "productCode", "产品编码" },{ "productName", "产品名称" },{ "customerCode", "客户编码" },{ "customerName", "客户名称" },{ "workordernumber", "工单编号" },{ "way", "方式" },{ "matnr", "物料编码" },{ "specs", "规格" },{ "dimension", "尺寸" },{ "equipmentnum", "设备编号" },{ "djBusCode", "业务代码" },{ "degEmCode", "异常代码" },{ "fqty", "数量" },{ "dinsert", "插入时间" },{ "lkstatus", "锁定状态" },{ "viewstatus", "查看状态" },{ "mst", "主状态" },{ "change_time", "变更时间" },{ "lgid", "lg的编号" },{ "lgmsg", "lg的信息" },{ "lgtime", "lg的时间" }};}private async void button1_Click(object sender, EventArgs e){_cancellationTokenSource = new CancellationTokenSource();string connectionString = "Server=ip;Database=root;User Id=1;Password=1;";string query = "SELECT * FROM [1].[1] where viewstatus=1";bool isConnected = await Task.Run(() => TestDatabaseConnection(connectionString));if (isConnected){textBox2.BackColor = Color.Green;label1.Text = "已连接";await Task.Run(() => MonitorDatabase(connectionString, query, _cancellationTokenSource.Token));}else{textBox2.BackColor = Color.Red;label1.Text = "连接失败";}}private bool TestDatabaseConnection(string connectionString){try{using (SqlConnection connection = new SqlConnection(connectionString)){connection.Open();return true;}}catch{return false;}}private void MonitorDatabase(string connectionString, string query, CancellationToken token){DateTime lastCheck = DateTime.Now;while (!token.IsCancellationRequested){using (SqlConnection connection = new SqlConnection(connectionString)){SqlCommand command = new SqlCommand(query, connection);command.Parameters.AddWithValue("@lastCheck", lastCheck);try{connection.Open();SqlDataReader reader = command.ExecuteReader();if (reader.HasRows){while (reader.Read()){StringBuilder result = new StringBuilder();for (int i = 0; i < reader.FieldCount; i++){string fieldName = reader.GetName(i);string fieldValue = reader[i].ToString();if (fieldMappings.ContainsKey(fieldName)){result.AppendLine($"{fieldMappings[fieldName]}: {fieldValue}");}else{result.AppendLine($"{fieldName}: {fieldValue}");}}UpdateUIWithResult(result.ToString(), reader);}lastCheck = DateTime.Now;}reader.Close();}catch (Exception ex){UpdateUIWithResult("Error: " + ex.Message, null);}}Thread.Sleep(1000); // 1 second interval}}private void UpdateUIWithResult(string text, SqlDataReader reader){if (InvokeRequired){Invoke(new Action(() => CreateLabelsForData(reader)));}else{CreateLabelsForData(reader);}}private void CreateLabelsForData(SqlDataReader reader){flowLayoutPanel1.Controls.Clear(); // 清空之前的控件int yOffset = 0; // 纵向偏移量for (int i = 0; i < reader.FieldCount; i++){string fieldName = reader.GetName(i);string fieldValue = reader[i].ToString();// 创建标题标签Label titleLabel = new Label{AutoSize = false,Width = 200,Height = 40,Location = new Point(0, yOffset),ForeColor = Color.Red,BackColor = Color.Black,Padding = new Padding(5),Font = new Font("Arial", 18, FontStyle.Bold),Text = fieldMappings.ContainsKey(fieldName) ? fieldMappings[fieldName] : fieldName};// 创建内容标签Label valueLabel = new Label{AutoSize = false,Width = 200,Height = 40,Location = new Point(210, yOffset),ForeColor = Color.Green,BackColor = Color.Black,Padding = new Padding(5),Font = new Font("Arial", 18, FontStyle.Regular),Text = fieldValue};// 将标题和内容标签添加到PanelflowLayoutPanel1.Controls.Add(titleLabel);flowLayoutPanel1.Controls.Add(valueLabel);yOffset += 50; // 更新纵向偏移量}}private void Form1_FormClosing(object sender, FormClosingEventArgs e){_cancellationTokenSource?.Cancel();}private void label1_Click(object sender, EventArgs e){}private void label2_Click(object sender, EventArgs e){}private void button5_Click(object sender, EventArgs e){_cancellationTokenSource?.Cancel();textBox2.BackColor = Color.WhiteSmoke; // 或者其他颜色表示断开连接label1.Text = "未连接";}private void flowLayoutPanel1_Paint(object sender, PaintEventArgs e){}}
}

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

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

相关文章

代码随想录算法训练营第四十五天 | 1049. 最后一块石头的重量 II、494. 目标和、474.一和零

1049. 最后一块石头的重量 II 视频讲解&#xff1a; 动态规划之背包问题&#xff0c;这个背包最多能装多少&#xff1f;LeetCode&#xff1a;1049.最后一块石头的重量II_哔哩哔哩_bilibili 代码随想录 解题思路 直接将这一些石头&#xff0c;分为两堆&#xff0c;让他们尽可能…

C语言 | Leetcode C语言题解之第120题三角形最小路径和

题目&#xff1a; 题解&#xff1a; int minimumTotal(int** triangle, int triangleSize, int* triangleColSize) {int f[triangleSize];memset(f, 0, sizeof(f));f[0] triangle[0][0];for (int i 1; i < triangleSize; i) {f[i] f[i - 1] triangle[i][i];for (int j …

【excel】设置二级联动菜单

文章目录 【需求】在一级菜单选定后&#xff0c;二级菜单联动显示一级菜单下的可选项【步骤】step1 制作辅助列1.列转行2.在辅助列中匹配班级成员 之前做完了 【excel】设置可变下拉菜单&#xff08;一级联动下拉菜单&#xff09;&#xff0c;开始做二级联动菜单。 【需求】在…

python实现——综合类型数据挖掘任务(无监督的分类任务)

综合类型数据挖掘任务 航空公司客户价值分析。航空公司客户价值分析。航空公司客户价值分析。航空公司已积累了大量的会员档案信息和其乘坐航班记录&#xff08;air_data.csv&#xff09;&#xff0c;以2014年3月31日为结束时间抽取两年内有乘机记录的所有客户的详细数据。利用…

万界星空科技MES系统功能介绍

制造执行系统或MES 是一个全面的动态软件系统&#xff0c;用于监视、跟踪、记录和控制从原材料到成品的制造过程。MES在企业资源规划(ERP) 和过程控制系统之间提供了一个功能层&#xff0c;为决策者提供了提高车间效率和优化生产所需的数据。 万界星空科技MES 系统基础功能&am…

【全开源】Java短剧系统微信小程序+H5+微信公众号+APP 源码

打造属于你的精彩短视频平台 一、引言&#xff1a;为何选择短剧系统小程序&#xff1f; 在当今数字化时代&#xff0c;短视频已经成为人们日常生活中不可或缺的一部分。而短剧系统小程序源码&#xff0c;作为构建短视频平台的强大工具&#xff0c;为广大开发者提供了快速搭建…

03-树1 树的同构(浙大数据结构PTA习题)

03-树1 树的同构 分数 25 作者 陈越 单位 浙江大学 给定两棵树 T1​ 和 T2​。如果 T1​ 可以通过若干次左右孩子互换就变成 T2​&#xff0c;则我们称两棵树是“同构”的。例如图1给出的两棵树就是同构的&#xff0c;因为我们把其中一棵树的结点A、B、G…

CSPM.pdf

PDF转图片 归档&#xff1a;

跨境电商多店铺:怎么管理?风险如何规避?

跨境电商的市场辽阔&#xff0c;有非常多的商业机会。你可能已经在Amazon、eBay、Etsy等在线平台向潜在客户销售产品了。为了赚更多的钱&#xff0c;你可能还在经营多个店铺和品牌。 但是&#xff0c;像Amazon、eBay、Etsy等知名平台会有自己的规则&#xff0c;他们开发了很多…

手拉手springboot整合kafka发送消息

环境介绍技术栈springbootmybatis-plusmysqlrocketmq软件版本mysql8IDEAIntelliJ IDEA 2022.2.1JDK17Spring Boot3.1.7kafka2.13-3.7.0 创建topic时&#xff0c;若不指定topic的分区(Partition主题分区数)数量使&#xff0c;则默认为1个分区(partition) springboot加入依赖kafk…

探索无限可能性——微软 Visio 2021 改变您的思维方式

在当今信息化时代&#xff0c;信息流动和数据处理已经成为各行各业的关键。微软 Visio 2021 作为领先的流程图和图表软件&#xff0c;帮助用户以直观、动态的方式呈现信息和数据&#xff0c;从而提高工作效率&#xff0c;优化业务流程。本文将介绍 Visio 2021 的特色功能及其在…

华为OD机试 - 游戏分组 - 递归(Java 2024 C卷 100分)

华为OD机试 2024C卷题库疯狂收录中&#xff0c;刷题点这里 专栏导读 本专栏收录于《华为OD机试&#xff08;JAVA&#xff09;真题&#xff08;A卷B卷C卷&#xff09;》。 刷的越多&#xff0c;抽中的概率越大&#xff0c;每一题都有详细的答题思路、详细的代码注释、样例测试…

精准检测,安全无忧:安全阀检测实践指南

安全阀作为一种重要的安全装置&#xff0c;在各类工业系统和设备中发挥着举足轻重的作用。 它通过自动控制内部压力&#xff0c;有效防止因压力过高而引发的设备损坏和事故风险&#xff0c;因此&#xff0c;对安全阀进行定期检测&#xff0c;确保其性能完好、工作可靠&#xf…

使用pytorch构建ResNet50模型训练猫狗数据集

数据集 1.导包 import torch import torch.nn as nn import torch.optim as optim from torch.utils.data import DataLoader from torchvision import datasets, transforms, models import numpy as np import matplotlib.pyplot as plt import os from tqdm.auto import t…

流媒体服务器SMS-语音对讲(一)

1.简介 在国标语音对讲对接中&#xff0c;会发现不同的厂商或不同型号的设备&#xff0c;对讲流程都不一样&#xff0c;本文主要介绍流媒体与设备之间的交互情况。 SMS流媒体服务代码库地址&#xff1a;https://gitee.com/inyeme/simple-media-server 2.流媒体与设备交互的可能…

max6675热电偶温度采集

思路来源 参考价格 概述 MAX6675具有冷端补偿和将来自K型热电偶的信号数字化。数据以12位分辨率输出&#xff0c;SPI™兼容&#xff0c; 只读格式。该转换器将温度分解为0.25C&#xff0c;允许读数高达1024C&#xff0c;并显示热电偶8LSB在0C至 700C 引脚连接 温度采样电路 …

中间件复习之-消息队列

消息队列在分布式架构的作用 消息队列&#xff1a;在消息的传输过程中保存消息的容器&#xff0c;生产者和消费者不直接通讯&#xff0c;依靠队列保证消息的可靠性&#xff0c;避免了系统间的相互影响。 主要作用&#xff1a; 业务解耦异步调用流量削峰 业务解耦 将模块间的…

MySQL之创建高性能的索引(八)

创建高性能的索引 覆盖索引 通常大家都会根据查询的WHERE条件来创建合适的索引&#xff0c;不过这只是索引优化的一个方面。设计优秀的索引应该考虑到整个查询&#xff0c;而不单单是WHERE条件部分。索引确实是一种查找数据的高效方式&#xff0c;但是MySQL也可以使用索引来直…

向量数据库引领 AI 创新——Zilliz 亮相 2024 亚马逊云科技中国峰会

2024年5月29日&#xff0c;亚马逊云科技中国峰会在上海召开&#xff0c;此次峰会聚集了来自全球各地的科技领袖、行业专家和创新企业&#xff0c;探讨云计算、大数据、人工智能等前沿技术的发展趋势和应用场景。作为领先的向量数据库技术公司&#xff0c;Zilliz 在本次峰会上展…

【漏洞复现】电信网关配置管理系统 rewrite.php 文件上传漏洞

0x01 产品简介 中国电信集团有限公司(英文名称"China Telecom”、简称“"中国电信”)成立于2000年9月&#xff0c;是中国特大型国有通信企业、上海世博会全球合作伙伴。电信网关配置管理系统是一个用于管理和配置电信网络中网关设备的软件系统。它可以帮助网络管理员…