【机房收费系统】——使用DataGridView遇到的问题

2024-08-26 14:58

本文主要是介绍【机房收费系统】——使用DataGridView遇到的问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

       机房收费系统里面不可避免的要使用DataGridView控件,目的是为了接收返回的泛型值或DataTable类型值,将返回的表显示到DataGridView中,最开始使用时,就想到了在第一次机房时vb中使用的控件MSHFlexGrid,那时候通过自己设计控件的属性,列的名称,并通过循环来给MSHFlexGrid赋值。当然,这只是一种方法,同样适用于VB.net中的DataGridView控件。

       有一种很简便的方法,那就是直接让DataGridView.DataSource=List,这样就可以直接将整个表赋值给DataGridView控件。但是,这种方式同样存在着缺点,那就是你会将返回的整个表的内容都赋给它。即使你不想让它显示出来的字段也会显示出来,比如说密码这种保密的信息。所以,这个时候,还是老老实实的用循环体给DataGridView赋值吧。

       开始写代码的时候,为了图方便,直接使用上面的方法,直到帮老崔解决问题的时候才意识到,并不是将所有的字段信息都返回才好。这个时候还是要使用循环体。


       问题一:索引超出范围,必须为非负值并小于集合大小。


       

       很明显,是索引超出范围,但是这个问题乍一看很常见,但是出现在这儿,却让人摸不到头脑,这也是当时老崔遇到的问题。当时是解决了,可是没有及时总结,后来自己又遇到了这个问题。费了半天劲,总算想起来第一次机房的时候用循环体,写完一行的内容后,需要增加下一行才能继续赋值,增加代码dgv.Rows.Add(1)。示例代码如下:

       

        '向DataGridView中添加数据For i = 0 To list.Count - 1dgv.Rows.Add(1)dgv.Rows(i).Cells(0).Value = list(i).User_IDdgv.Rows(i).Cells(1).Value = list(i).Login_Datedgv.Rows(i).Cells(2).Value = list(i).Login_Timedgv.Rows(i).Cells(3).Value = list(i).ComputerNext


       问题二:不能向没有列的DataGridView控件添加行。必须首先添加列。


       

       这个问题,看完解释信息,大家都明白是由于没有定义列,所以在用循环体给DataGridView赋值时导致赋值失败。问题描述确实很简单,但最让自己纳闷的就是,明明已经定义列了,却还是报这个错。想了半天,也不知道是哪的错。经历千万番尝试,突然发现,自己每次在单击事件里面都有DataGridView.Column.Clear()。果然,这句话的意思就是将DataGridView的内容都删除的。只需要改成DataGridView.Rows.Clear()就可以了。


       总结:


       对于DataGridView控件的使用还有很多的方法,比如可以和数据源进行绑定,直接将数据库中的表映射过来;还有DataGridView的属性,可以在显示的记录前加复选框,然后可以选中多行,方便添加和删除等等。通过这些小的错误,也反应出了细节的重要性,细节往往能决定成败!

这篇关于【机房收费系统】——使用DataGridView遇到的问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1108884

相关文章

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

MySQL中EXISTS与IN用法使用与对比分析

《MySQL中EXISTS与IN用法使用与对比分析》在MySQL中,EXISTS和IN都用于子查询中根据另一个查询的结果来过滤主查询的记录,本文将基于工作原理、效率和应用场景进行全面对比... 目录一、基本用法详解1. IN 运算符2. EXISTS 运算符二、EXISTS 与 IN 的选择策略三、性能对比

使用Python构建智能BAT文件生成器的完美解决方案

《使用Python构建智能BAT文件生成器的完美解决方案》这篇文章主要为大家详细介绍了如何使用wxPython构建一个智能的BAT文件生成器,它不仅能够为Python脚本生成启动脚本,还提供了完整的文... 目录引言运行效果图项目背景与需求分析核心需求技术选型核心功能实现1. 数据库设计2. 界面布局设计3

使用IDEA部署Docker应用指南分享

《使用IDEA部署Docker应用指南分享》本文介绍了使用IDEA部署Docker应用的四步流程:创建Dockerfile、配置IDEADocker连接、设置运行调试环境、构建运行镜像,并强调需准备本... 目录一、创建 dockerfile 配置文件二、配置 IDEA 的 Docker 连接三、配置 Do

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

Android Paging 分页加载库使用实践

《AndroidPaging分页加载库使用实践》AndroidPaging库是Jetpack组件的一部分,它提供了一套完整的解决方案来处理大型数据集的分页加载,本文将深入探讨Paging库... 目录前言一、Paging 库概述二、Paging 3 核心组件1. PagingSource2. Pager3.

解决RocketMQ的幂等性问题

《解决RocketMQ的幂等性问题》重复消费因调用链路长、消息发送超时或消费者故障导致,通过生产者消息查询、Redis缓存及消费者唯一主键可以确保幂等性,避免重复处理,本文主要介绍了解决RocketM... 目录造成重复消费的原因解决方法生产者端消费者端代码实现造成重复消费的原因当系统的调用链路比较长的时

python使用try函数详解

《python使用try函数详解》Pythontry语句用于异常处理,支持捕获特定/多种异常、else/final子句确保资源释放,结合with语句自动清理,可自定义异常及嵌套结构,灵活应对错误场景... 目录try 函数的基本语法捕获特定异常捕获多个异常使用 else 子句使用 finally 子句捕获所

深度解析Nginx日志分析与499状态码问题解决

《深度解析Nginx日志分析与499状态码问题解决》在Web服务器运维和性能优化过程中,Nginx日志是排查问题的重要依据,本文将围绕Nginx日志分析、499状态码的成因、排查方法及解决方案展开讨论... 目录前言1. Nginx日志基础1.1 Nginx日志存放位置1.2 Nginx日志格式2. 499

C++11右值引用与Lambda表达式的使用

《C++11右值引用与Lambda表达式的使用》C++11引入右值引用,实现移动语义提升性能,支持资源转移与完美转发;同时引入Lambda表达式,简化匿名函数定义,通过捕获列表和参数列表灵活处理变量... 目录C++11新特性右值引用和移动语义左值 / 右值常见的左值和右值移动语义移动构造函数移动复制运算符