C#使用MiniExcel读取excel表格文件

使用MiniExcel读取excel表格文件

MiniExecl提供了几种读取方法。

准备测试数据

测试类:

   public class Person{public int Id { get; set; }public string Name { get; set; }public string Description { get; set; }public double Value { get; set; }}

测试数据:

在这里插入图片描述

方法一:以行列号来读取

使用MiniExcel.Query方法读取一个IEnumerable<dynamic>动态类型dynamic的集合

 var rows = MiniExcel.Query("test1.xlsx").ToList();

在这里插入图片描述

然后使用rows[0].A使用行号获取第几行,然后使用列号A、B、C…来获取对应的单元格的值

打断点可以看到各列的值的类型,读出来的都是dynamic,但是实际是由对应的类型,带字符的基本都是string,数值类型都是double,需要自己先处理一下

在这里插入图片描述

A,B,C列都是动态类型,但是实际数据根据单元格里数据不同,类型不同,可以统一对数据进行转换

/// <summary>
/// 动态类型转字符串,自动判空
/// </summary>
/// <param name="data"></param>
/// <returns></returns>
public string DynamicToString(dynamic data)
{return data == null ? "" : (string)data.ToString();
}

完整代码:

  private void Init(){//方法1var rows = MiniExcel.Query("test1.xlsx").ToList();for (int i = 1; i < rows.Count; i++)//跳过首行{Person person = new Person{Id = int.Parse(DynamicToString(rows[i].A)),Name = DynamicToString(rows[i].B),Description = DynamicToString(rows[i].C),Value = double.Parse(DynamicToString(rows[i].D)),};list.Add(person);}}/// <summary>/// 动态类型转字符串,自动判空/// </summary>/// <param name="data"></param>/// <returns></returns>public string DynamicToString(dynamic data){return data == null ? "" : (string)data.ToString();}

效果:
在这里插入图片描述

方法二:使用第一行的名称进行读取

使用首行(标题行)的名称进行读取

在这里插入图片描述

读取的方法:

添加参数,设置使用头行读取,useHeaderRow: true

   var rows = MiniExcel.Query("test1.xlsx", useHeaderRow: true).ToList();

在这里插入图片描述

此时,读取的集合中已经没有首行,可以不用特殊处理

var rows = MiniExcel.Query("test1.xlsx", useHeaderRow: true).ToList();for (int i = 0; i < rows.Count; i++){Person person = new Person{Id = int.Parse(DynamicToString(rows[i].Id)),Name = DynamicToString(rows[i].Name),Description = DynamicToString(rows[i].Description),Value = double.Parse(DynamicToString(rows[i].Value)),};list.Add(person);}

实现效果一样

方法三:反序列化

首行标题跟类的属性名称一样,可以直接进行转换类型

在这里插入图片描述

直接返回对应类型的集合

 var rows = MiniExcel.Query<Person>("test1.xlsx").ToList();

这种方法最简单,但是对表格格式要求比较高,第一行必须为首行,否则无法实现

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

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

相关文章

QT信号与槽实现方式

1、第一种实现方式 在QT开发工具UI界面先拖入按钮&#xff0c;然后鼠标右键拖入按钮&#xff0c;点击选中槽&#xff0c;在页面选着需要的信号&#xff0c;然后OK&#xff0c;随即将会跳转到类的.cpp文件&#xff0c;&#xff08;这种UI代码结合的方式&#xff0c;会自动去绑定…

什么是分段锁?

1、典型回答 分段锁是一种将锁细化到每个段(Segment) 级别的锁设计。在 ConcurrentHashMap 中&#xff0c;它将整个数据结构分成多个段&#xff0c;每个段只锁定自己的一部分数据。每个段可以看作是一个独立的分组&#xff0c;只锁定该段(Segment)内部的数据操作&#xff0c;不…

springboot271制造装备物联及生产管理ERP系统

制造装备物联及生产管理ERP系统设计与实现 摘 要 传统办法管理信息首先需要花费的时间比较多&#xff0c;其次数据出错率比较高&#xff0c;而且对错误的数据进行更改也比较困难&#xff0c;最后&#xff0c;检索数据费事费力。因此&#xff0c;在计算机上安装制造装备物联及…

Mysql 无法启动,mysql-bin.日志丢失删除处理

在linux操作系统中&#xff0c;当mysql无法启动时候&#xff0c;先看日志 2024-03-15T05:20:16.352075Z 0 [Warning] [MY-000081] [Server] option max_allowed_packet: unsigned value 107374182400 adjusted to 1073741824. 2024-03-15T05:20:16.352156Z 0 [Warning] [MY-010…

【数据结构和算法初阶(C语言)】栈的概念和实现(后进先出---后来者居上的神奇线性结构带来的惊喜体验)

目录 1.栈 1.1栈的概念及结构 2.栈的实现 3.栈结构对数据的处理方式 3.1对栈进行初始化 3.2 从栈顶添加元素 3.3 打印栈元素 3.4移除栈顶元素 3.5获取栈顶元素 3.6获取栈中的有效个数 3.7 判断链表是否为空 3.9 销毁栈空间 4.结语及整个源码 1.栈 1.1栈的概念及结构 栈&am…

手撸dynamic源码详细讲解

本文源码解析基于3.3.1版本。只截了重点代码&#xff0c;如果需要看完整代码&#xff0c;可以去github拉取。 1 自动配置的实现 一般情况下&#xff0c;一个starter的最好入手点就是自动配置类&#xff0c;在 META-INF/spring.factories文件中指定自动配置类入口 org.spring…

QTextToSpeech的使用——Qt

前言 之前随便看了几眼QTextToSpeech的帮助就封装使用了&#xff0c;达到了效果就没再管了&#xff0c;最近需要在上面加功能&#xff08;变换语速&#xff09;&#xff0c;就写了个小Demo后&#xff0c;发现不对劲了。 出现的问题 场景 写了个队列添加到语音播放子线程中&a…

Jenkins cron定时构建触发器

from&#xff1a; https://www.jenkins.io/doc/book/pipeline/syntax/#cron-syntax 以下内容为根据Jenkins官方文档cron表达式部分翻译过来&#xff0c;使用机翻加个人理解补充内容&#xff0c;包括举例。 目录 介绍举例&#xff1a;设置方法方法一&#xff1a;方法二&#xf…

UG NX二次开发(C#)-单选对话框UF_UI_select_with_single_dialog的使用

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 1、前言2、UF_UI_select_with_single_dialog函数3、实现代码3.1 利用委托创建一个方法3.2 直接调用1、前言 对于单选对话框,采用C++/C写的时候比较容易,也在帮助文档中有示例,但是对于C#开发采…

C# StartsWith 字符串的实例方法

在 C# 中&#xff0c;StartsWith 是一个字符串的实例方法&#xff0c;用于检查字符串是否以指定的前缀开头。它返回一个布尔值&#xff0c;指示字符串是否以指定的前缀开始。 以下是 StartsWith 方法的详细解释和示例说明&#xff1a; public bool StartsWith(string value);…

EtherCAT运动控制器在ROS上的应用(下)

本篇文章我们主要介绍正运动技术动态链接库环境配置以及EtherCAT运动控制器在ROS下的单轴运动。 在正式学习之前&#xff0c;我们先了解一下正运动技术的EtherCAT运动控制器ZMC432和ZMC408CE。这两款产品分别是32轴&#xff0c;8轴EtherCAT运动控制器。 ZMC432功能简介 ZMC4…

List(CS61B学习记录)

问题引入 上图中&#xff0c;赋给b海象的weight会改变a海象的weight&#xff0c;但x的赋值又不会改变y的赋值 Bits 要解释上图的问题&#xff0c;我们应该从Java的底层入手 相同的二进制编码&#xff0c;却因为数据类型不同&#xff0c;输出不同的值 变量的声明 基本类型…