有时候我们需要展示表格格式的数据,首先想到的是用datagridview控件,比如更改datagridview某一行的数据,这样操作起来就比较麻烦,而listview属于轻量级,刷新和更改相对来说效率比较高。

首先展示最终结果:

实现步骤:

1.在设计里创建listview控件。

2.编辑列,可根据自己需求更改Name、Text、TextAlign、Width等。

3.设置View属性为 Details(细节),此时即可以显示列名

4.设置GridLines为True显示表格线,设置FullRowSelect为True单击某个单元格选中一行。

最后结果如下:

关键部分代码:

        private void Form4_Load(object sender, EventArgs e)
{
string epc = "E20001234567890123456789";
string dateTime = System.DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss:fff");
string antPort = "";
string clientIp = "10.10.10.80"; bool findFlag = false; //默认为当前epc不存在列表中
int itemIdx = ; //listview索引 foreach (KeyValuePair<int, string> item in dicInventoryData)
{
if (item.Value.Contains(epc))
{
findFlag = true;
itemIdx = item.Key;
}
} if (findFlag) //存在,更新数据
{
// 更新次数
listInventoryData.Items[itemIdx].SubItems[].Text = Int32.Parse(listInventoryData.Items[itemIdx].SubItems[].Text) + + "";
//更新时间
listInventoryData.Items[itemIdx].SubItems[].Text = dateTime; // 取天线信息
string strAntennaPorts = listInventoryData.Items[itemIdx].SubItems[].Text;
if (!strAntennaPorts.Contains(antPort))
{
// 更新天线信息
strAntennaPorts += "," + antPort;
listInventoryData.Items[itemIdx].SubItems[].Text = strAntennaPorts;
}
}
else //不存在,添加数据
{
ListViewItem item = new ListViewItem();
//序号
item.Text = (listInventoryData.Items.Count + ) + "";
//客户端
item.SubItems.Add(clientIp);
//epc
item.SubItems.Add(epc);
//天线号
item.SubItems.Add(antPort);
// 次数
item.SubItems.Add("");
//时间
item.SubItems.Add(dateTime); listInventoryData.BeginUpdate();
listInventoryData.Items.Add(item);
listInventoryData.EndUpdate();
// 添加到列表
dicInventoryData.Add((int)imparityCount, epc);
// 标签个数加1
imparityCount++;
}
}

常用属性:

  1.HeaderStyle - “详细信息”视图中列标头的样式。

    None - 不显示列标头

    Nonclickable - 不可点击

    Clickable - 可点击

  2.HideSelection - 当控件没有焦点时,移除选定项的突出显示。

  3.MultiSelect - 允许选择多项 (True/False)。

  4.CheckBoxes - 指示复选框是否显示在项旁边。

  5.FullRowSelect - 指示当项被选中时,其所有子项是否同该项一起突出显示。

  6.GridLines - 在项和子项周围显示网格线。仅在“详细信息”视图中显示。

  7.View - 选择可以显示项的不同视图中的一种。

常用方法:

1.BeginUpdate:避免在调用EndUpdate 方法之前描述控件。当插入大量数据时,可以有效地避免控件闪烁,并能大大提高速度。

2.EndUpdate:在BeginUpdate 方法挂起描述后,继续描述列表视图控件。(结束更新)

3.EnsureVisible:列表视图滚动定位到指定索引项的选项行。(效果类似于TopItem属性)

4.FindItemWithText:查找以给定文本值开头的第一个 ListViewItem。

5.FindNearestItem:按照指定的搜索方向,从给定点开始查找下一个项。提示:只有在LargeIcon或SmallIcon视图才能使用该方法。

常用事件:

1.AfterLabelEdit:当用户编辑完项的标签时发生,需要LabelEdit属性为true。

2.BeforeLabelEdit:当用户开始编辑项的标签时发生。

3.ColumnClick:当用户在列表视图控件中单击列标头时发生。

参考:

https://www.cnblogs.com/shadowme/p/6250070.html

https://www.cnblogs.com/qq450867541/p/6164936.html

C# listview展示表格格式的更多相关文章

  1. 传入的表格格式数据流(TDS)远程过程调用(RPC)协议流不正确。此 RPC 请求中提供了过多的参数。最多应为 2100

    出现这个问题的背景是,判断一批激活码在系统中是否已经存在,很傻的一个作法是,把这一批激活码,以in(in (‘ddd‘,‘aaa‘))的形式来处理,导致问题的出现. 后来,查找资料,http://bb ...

  2. 转:传入的表格格式数据流(TDS)远程过程调用(RPC)协议流不正确 .

    近期在做淘宝客的项目,大家都知道,淘宝的商品详细描述字符长度很大,所以就导致了今天出现了一个问题 VS的报错是这样子的  ” 传入的表格格式数据流(TDS)远程过程调用(RPC)协议流不正确“ 还说某 ...

  3. SQLServer 2000 Driver for JDBC][SQLServer]传入的表格格式数据流(TDS)远程过程调用(RPC)协议流不正确解决方法

    问题:[SQLServer 2000 Driver for JDBC][SQLServer]传入的表格格式数据流(TDS)远程过程调用(RPC)协议流不正确.参数 1 (""): ...

  4. Xamarin.Android 调用Web Api(通过ListView展示远程获取的数据)

    xamarin.android如何调用sqlserver 数据库呢(或者其他的),很多新手都会有这个疑问.xamarin.android调用远程数据主要有两种方式: 在Android中保存数据或调用数 ...

  5. 安卓TextView完美展示html格式代码

    对于TextView展示html格式代码,最简单的办法就是使用textview.setText(Html.fromHtml(html));,即便其中有img标签,我们依然可以使用ImageGetter ...

  6. Vue之展示PDF格式的文档

    事实上有很多种在前端展示PDF格式文档的方法,小编也用过好多种,例如有<iframe>.<embed>和<object>这些标签,但是在Vue项目里,这些方法都不能 ...

  7. SQL :“传入的表格格式数据流(TDS)远程过程调用(RPC)协议流不正确” 错误

    其中在DAL层调用存储过程来插入数据的参数 SqlParameter[] parameters = {                                            new S ...

  8. sqlserver2008 传入的表格格式数据流(tds)协议流不正确。

    起因是在sql 2008 里使用 sql prompt 报了一个内部连接致命错误,原本应该想到是数据库连接问题的,奇怪的是能连接上数据库也能查询表仅仅是用不了工具没有智能提示. 几经查询无果,度娘上之 ...

  9. 解决invalid record found in VCF4 file (at least 8 tab-delimited fields expected)问题,批量修改空格改为制表格格式

    出现这种问题说明一般存在两个问题: 第一,vcf文件不足8个分割制表符,比如像如下文件: 为了解决这个问题,说明在做snp filter时候,需要提取至少8个制表符的字符串,比如,像如下文件所示: 第 ...

随机推荐

  1. 记录vue项目上线遇到的一些问题

    1. 静态资源路径不对,在开发模式下正常,打包到服务器上的时候,发现静态资源全部请求不到 原因:开发模式下,本地静态服务器直接从项目目录直接起的,跟static是同目录,写绝对路径没问题,直接loca ...

  2. 我们为什么不用 Select * 吗?

    应用程序慢如牛,原因多多,可能是网络的原因.可能是系统架构的原因,还有可能是数据库的原因. 那么如何提高数据库SQL语句执行速度呢?有人会说性能调优是数据库管理员(DBA)的事,然而性能调优跟程序员们 ...

  3. 2016-3-1 安装Hexo过程中遇到的问题

      查找问题地址: http://hexo.io/docs/troubleshooting.html   1.通过npm安装hexo运行命令:sudo npm install -g hexo 出现这个 ...

  4. echarts中的区域缩放组件dataZoom,主动触发选区缩放点击事件

    options设置 toolbox: { // 工具栏 feature: { dataZoom : { // 选时间缩放功能 show : true, // show为true时,才能触发takeGl ...

  5. webstorm2018.2.3激活

    一,简介 WebStorm 是jetbrains公司旗下一款JavaScript 开发工具.目前已经被广大中国JS开发者誉为"Web前端开发神器"."最强大的HTML5编 ...

  6. 读 Spring实战 遇到的问题记录(一)

    package soundsystem; import beanConfig.CDPlayerConfig; import org.junit.Rule; import org.junit.Test; ...

  7. input框中修改placeholder的样式

    有时间input标签的placeholder属性会出现问题,下面是修改placeholder的样式demo input::-webkit-input-placeholder{ color:red; f ...

  8. 可视化利器Visdom

    可视化利器Visdom 最近在使用Pytorch炼丹,单纯地看命令行输出已经无法满足调试的需求,尝试了facebook开源的visdom,感觉非常优雅,支持numpy和torch 安装 $ pip i ...

  9. oracle 报错无法从套接字获取更多数据

    报错信息如下: ---查看_optimizer_join_elimination_enabled参数值 切换sys用户 select a.ksppinm name, b.ksppstvl value, ...

  10. java.lang.ClassCastException: net.sf.json.JSONNull cannot be cast to net.sf.json.JSONObject的解决方法

    报错情况已经说明了,在百度查了好几个解决方法,这里总结一下: 首先:加一个判断是否为空,再做操作 // 得到json串 String jsonString = UtilPOSTGET.UPost(FO ...