首页 程序笔记 C# Winform使用DataGridView显示表格数据

C# Winform使用DataGridView显示表格数据

DataGridView的常见应用

DataGridView是.NET框架中用于显示、编辑和操作数据表格的控件。它提供了一个灵活的方式来显示和操作大量的数据。以下是对DataGridView的一些常见应用和实现的总结:

数据显示:DataGridView可以用于显示来自各种数据源的数据,包括数据库、数组、列表等,可以直接将数据源绑定到DataGridView,或者通过代码逐行填充数据。 列自定义:可以自定义DataGridView的列,包括设置列的宽度、可见性、排序方式、文本等,还可以添加按钮列,以允许用户执行操作,如编辑、删除等。 行选择:DataGridView支持多选,用户可以通过Ctrl或Shift键选择多行,也可以通过代码来选择特定的行。 事件处理:DataGridView支持各种事件,如点击事件、数据更改事件等,可以通过编写事件处理程序来响应用户的操作,例如点击按钮列的按钮或者更改选中的行。 数据绑定:DataGridView可以与数据源进行双向绑定,这意味着当用户更改DataGridView中的数据时,数据源中的数据也会相应地更改,反之亦然。 数据排序:DataGridView支持自动和手动排序,可以通过设置SortMode属性为Automatic或Programmatic来启用自动排序。 分页:虽然DataGridView本身并没有内置分页功能,但可以通过在数据源中实现分页,或者使用第三方库来实现分页。

DataGridView控件的使用方法

1、创建一个Windows窗体应用程序,并添加一个DataGridView控件到窗体上。

2、在代码文件中,定义一个数据源,例如一个包含学生信息的DataTable:

DataTable students = new DataTable();  
students.Columns.Add("ID", typeof(int));  
students.Columns.Add("Name", typeof(string));  
students.Columns.Add("Age", typeof(int));

3、将数据源绑定到DataGridView控件上:

dataGridView1.DataSource = students;

4、在DataGridView控件中添加列和行,以及设置列和行的属性:

dataGridView1.Columns["ID"].HeaderText = "学号";  
dataGridView1.Columns["Name"].HeaderText = "姓名";  
dataGridView1.Columns["Age"].HeaderText = "年龄";

5、添加数据到DataGridView控件中:

// 添加10条数据到DataGridView控件中  
for (int i = 0; i < 10; i++)  
{  
    DataRow row = students.NewRow();  
    row["ID"] = i + 1;  
    row["Name"] = "学生" + (i + 1);  
    row["Age"] = i * 2 + 10;  
    students.Rows.Add(row);  
}

DataGridView完整应用示例

using System;
using System.Data;
using System.Windows.Forms;

namespace WinForm_DataGridView
{
    public partial class Form1 : Form
    {
        // 定义一个DataTable作为数据源  
        private DataTable students = new DataTable();

        public Form1()
        {
            InitializeComponent();
            // 初始化DataGridView控件  
            InitializeDataGridView();
        }

        // 初始化DataGridView控件  
        private void InitializeDataGridView()
        {
            // 添加列到数据源  
            students.Columns.Add("ID", typeof(int));
            students.Columns.Add("Name", typeof(string));
            students.Columns.Add("Age", typeof(int));

            // 将数据源绑定到DataGridView控件上  
            dataGridView1.DataSource = students;

            // 设置列标题  
            dataGridView1.Columns["ID"].HeaderText = "学号";
            dataGridView1.Columns["Name"].HeaderText = "姓名";
            dataGridView1.Columns["Age"].HeaderText = "年龄";
        }

        // 加载按钮的点击事件处理程序  
        private void btnLoadData_Click(object sender, EventArgs e)
        {
            // 添加10条数据到DataGridView控件中  
            AddDataToDataGridView();
        }

        // 添加10条数据到DataGridView控件中  
        private void AddDataToDataGridView()
        {
            for (int i = 0; i < 20; i++)
            {
                DataRow row = students.NewRow();
                row["ID"] = i + 1;
                row["Name"] = "学生" + (i + 1);
                row["Age"] = i * 2 + 10;
                students.Rows.Add(row);
            }
        }
    }
}

运行结果

1

站心网

DataGridView的常见应用 DataGridView是.NET框架中用于显示、编辑和操作数据表格的控件。它提供了一个灵活..

为您推荐

实时数据的处理一致性如何保证?

实时数据一致性的定义以及面临的挑战数据一致性通常指的是数据在整个系统或多个系统中保持准确、可靠和同步的状态。在实时数据处理中,一致性包括但不限于数据的准确性、完整性、时效性和顺序性。下图是典型的实时/..

关于大数据的一些真知灼见

大数据很强大,但还是有很多人仍然不知道它到底是什么。让我们来学习大数据的真实表现,以及如何更好地促进企业转型。或许我们经常听到有人讲大数据,但仍然有很多人不知道它到底是什么。因为我确信它很强大,所以我..

.net环境下跨进程、高频率读写数据

一、需求背景1、最近项目要求高频次地读写数据,数据量也不是很大,多表总共加起来在百万条上下。单表最大的也在25万左右,历史数据表因为不涉及所以不用考虑,难点在于这个规模的热点数据,变化非常频繁。数据来源..

工作中人们常提到的数据预处理,说的到底是什么?

数据预处理一方面是为了提高数据的质量,另一方面也是为了适应所做数据分析的软件或者方法。在做数据分析时,我想许多数据分析师会像《R语言实战第二版》的作者卡巴科弗那样发出感叹:“数据分析师在数据预处理上花..

使用 html2canvas 实现截图功能

html2canvas 是一个开源的 JavaScript 库,用于将网页上的 HTML 元素渲染成图像。它通过遍历页面的 DOM 树和计算样式,然后将其绘制到 <canvas> 元素上,最终生成图片。该库不依赖服务器端,而是通过浏览器端的 Java..

使用SuperWebSocket实现Web消息推送

在大部分Web系统中,我们可能遇到需要向客户端推送消息的需求。SuperWebSocket第三方库能让我们轻松的完成任务。SuperWebSocket第三方库可以从网上下载,不过通过Visual Studio Nuget安装更快。引用SuperWebSocket相..

.NET C# 使用Hook钩子实现全局监听键盘和鼠标

C# 是一种面向对象的编程语言,具有丰富的类库和工具支持,适用于各种类型的应用程序开发。Windows 提供了一种称为"钩子"(Hook)的机制,允许拦截并处理系统级别的事件,如键盘按键和鼠标移动。通过结合 C# 和 Hook..

C#使用 Attribute 实现 AOP 功能

在 C# 中,通过自定义 Attribute 并结合一些技术(如动态代理、反射等)可以实现 AOP(面向切面编程)。AOP 通常用于日志记录、性能监控、权限验证等横切关注点。以下是一个使用 C# Attribute 实现 AOP 功能的示例。..

ABP.Net Core使用教程(一)启动模版项目

只需要简单的3步:1,到官网下载模版项目 https://aspnetboilerplate.com/Templates2,用VS2017打开,将Web.Host设置为启动项3,在程序包管理器控制台(Nuget控制台)里设定默认项目为EntityFrameworkCore,执行命令..

C#中的线程安全的集合ConcurrentQueue使用示例

在多线程编程中,如何安全地在不同线程之间共享数据是一个非常重要的问题。C# 为我们提供了一些专门设计的线程安全集合,其中之一就是 ConcurrentQueue<T>。它是一种先进先出(FIFO)的数据结构,专门为多线程环境设..

CSS砌体布局示例和使用场景

CSS砌体布局(Masonry Layout)CSS砌体布局是一种网页布局技术,它的灵感来源于砖石墙的排列方式,类似于“拼图”或“拼砖”的效果。在砌体布局中,元素的排列并不完全遵循传统的网格布局规则,..

使用CSS columns-visibility实现砌体布局

CSS的 columns 属性(如 columns、column-count 和 column-width)通常用于多列文本布局,而不是直接用于砌体布局。然而,结合 columns 和 visibility 属性,可以在某些情况下实现类似砌体布局的效果,虽然它并不完..

mysql随机获取一条或者多条数据

语句一:select * from users order by rand() LIMIT 1MYSQL手册里面针对RAND()的提示大概意思就是,在 ORDER BY从句里面不能使用RAND()函数,因为这样会导致数据列被多次扫描,导致效率相当相当的低,效率不行,切..

使用System.Linq.Dynamic.Core扩展库动态构建 LINQ 查询

System.Linq.Dynamic.Core 是一个扩展库,用于在运行时动态构建 LINQ 查询,支持字符串形式的表达式解析和动态查询操作。它是 .NET 的一个强大工具,适合处理需要灵活定义查询逻辑的场景,例如动态过滤、排序、投影..

小米开源智能家居平台 ha_xiaomi_home 使用示例

小米近期在 GitHub 上开源了名为“ha_xiaomi_home”的项目,即 Home Assistant 米家集成组件。该组件由小米官方支持,旨在让用户在 Home Assistant 中集成和控制小米 IoT 智能设备。主要特点:官方支持:..

多语言网站数据库文章表设计

设计一个支持多语言的网站数据库时,应该确保内容能够方便地扩展和管理。以下是多语言数据库表设计的关键原则和示例:设计原则分离内容与语言:将与语言相关的内容独立存储,不直接硬编码到主要表中。每个支持多语言..

C#13新特性 使用System.Threading.Lock简化线程同步

C# 13 引入了新的线程同步类型 System.Threading.Lock,它通过作用域管理的方式简化了锁的使用,使代码更加清晰可靠。本文将全面介绍 System.Threading.Lock 的功能、适用场景,并提供完整的运行示例程序。1. 什么是..

微软官方Microsoft.Extensions.AI库使用示例

Microsoft.Extensions.AI 库介绍Microsoft.Extensions.AI 是一个扩展库,用于在 .NET 应用程序中轻松集成人工智能(AI)服务,例如 OpenAI、Azure OpenAI 和其他支持文本生成或语言模型的 API。通过与 Microsoft.Ext..

.Net Core中Dapper的使用详解

1.安装Dapper这里直接使用Nuget安装。安装版本是1.50.5安装完成之后,发现Nuget下已经有了Dapper。2.创建DapperHelper接下来创建一个DapperHelper帮助类,来进行读取数据库连接字符串,打开数据库等操作。public cla..

最新CentOS7安装搭建shadowsocks服务端+客户端使用图文教程

使用的CentOS版本是7.9,其他版本也可以。超级推荐的是搭建shadowsocks服务端,安装配置都很简单,几分钟就搞定,客户端支持PC移动端,下面是安装shadowsocks的过程,只要复制粘贴命令就行了,文件夹路径都不需要改..

发表回复

返回顶部