情不知从何起,一往而情深
排名
6
文章
199
粉丝
4
评论
3
ICP备案 :渝ICP备18016597号-1
网站信息:2018-2025TNBLOG.NET
技术交流:群号656732739
联系我们:contact@tnblog.net
公网安备:50010702506256
欢迎加群交流技术

c# 根据泛型返回任意类型

3788人阅读 2023/2/23 10:17 总访问:1110522 评论:0 收藏:0 手机
分类: .net

注意通过这种方式,类型要能转化成功才行,不然会报类型转化的错误的

  1. /// <summary>
  2. /// 根据传递过来的泛型来获取对应的类型数据
  3. /// </summary>
  4. /// <typeparam name="T"></typeparam>
  5. /// <param name="hSSFCell"></param>
  6. /// <returns></returns>
  7. private T GetCellValue<T>(NPOI.SS.UserModel.ICell hSSFCell)
  8. {
  9. Type t = typeof(T);
  10. if (hSSFCell == null)
  11. {
  12. return default(T);
  13. }
  14. if (hSSFCell.CellType == NPOI.SS.UserModel.CellType.Numeric)
  15. {
  16. // NPOI中数字和日期都是NUMERIC类型的,这里对其进行判断是否是日期类型
  17. if (NPOI.SS.UserModel.DateUtil.IsCellDateFormatted(hSSFCell))
  18. {
  19. return (T)(object)hSSFCell.DateCellValue;
  20. }
  21. return (T)(object)hSSFCell.NumericCellValue;
  22. }
  23. if (hSSFCell.CellType == NPOI.SS.UserModel.CellType.String)
  24. {
  25. return (T)(object)hSSFCell.StringCellValue;
  26. }
  27. if (hSSFCell.CellType == NPOI.SS.UserModel.CellType.Boolean)
  28. {
  29. return (T)(object)hSSFCell.BooleanCellValue;
  30. }
  31. if (hSSFCell.CellType == NPOI.SS.UserModel.CellType.Blank)
  32. {
  33. return default(T);
  34. }
  35. if (hSSFCell.CellType == NPOI.SS.UserModel.CellType.Error)
  36. {
  37. return (T)(object)hSSFCell.ErrorCellValue;
  38. }
  39. return default(T);
  40. }

欢迎加群讨论技术,1群:677373950(满了,可以加,但通过不了),2群:656732739。有需要软件开发,或者学习软件技术的朋友可以和我联系~(Q:815170684)

评价

css弹性盒子,flex布局

css弹性盒子由于版本不同浏览器问题造成了一些不同的写法display:flexbox;在google浏览器中如果使用下面的写法就不行displa...

css图片和文字对齐问题

文字和图片写到一排经常会出现对不齐的问题 这样感觉图片会上来一点没有和文字对齐,如下图 但是如果修改下html结...

GitHub 上传项目

补充简化方法:登录git创建项目--&gt;拉取刚刚创建的项目--&gt;复制需要的代码进去--&gt;上传提交即可先拉取项目在上传代码...

NET core 使用 EF code First

下面这些内容很老了看这篇:https://www.tnblog.net/aojiancc2/article/details/5365 项目使用多层,把数据库访问...

Windows平台分布式架构实践 - 负载均衡

原文地址: https://www.cnblogs.com/atree/p/windows_loadbalancer.html 概述  最近.NET的世界开始闹腾了,微软官方终...

css实现简单矩形对话框

在前端做项目时,我们可能会遇到写对话框的需求,这次做视频会议页面就遇到了,记录下日后有个参照。//网页部分 &lt;divcla...

cAPS.NET 保存base64位格式的图片

publicvoidUpload() { //取出图片对应的base64位字符 stringimgBase=Request[&quot;imgBase&quot;]; //c#里边的base6...

使用OLEDB读取不同版本Excel的连接字符串设置

使用OleBD读取excel的时候,excel不同的版本,连接字符串的写法也会不一样。///&lt;summary&gt; ///读取excel ///&lt;/su...

vs2017 对 cOM 组件的调用返回了错误 HRESULT E_FAIL

vs2017添加引用报错 对 COM 组件的调用返回了错误 HRESULT E_FAIL 1.以管理员身份打开vs2017开发人员命令指示符 2...

分布式服务架构与微服务架构概念的区别与联系

分布式:分散压力。微服务:分散能力。当下理解分布式:不同模块部署在不同服务器上作用:分布式解决网站高并发带来问题集...

分布式-微服务-集群的区别

1.分布式将一个大的系统划分为多个业务模块,业务模块分别部署到不同的机器上,各个业务模块之间通过接口进行数据交互。区...

NPOI操作excel 2007/2010版本

HSSFWorkbook:是操作Excel2003以前(包括2003)的版本,扩展名是.xlsXSSFWorkbook:是操作Excel2007的版本,扩展名是.xlsx先...

这样学英语三个月超过你过去学三年

本文作者三年间从四级勉强及格到高级口译笔试210,口试232。找工作面试时给其口试的老外考官听了一分钟就说你的英语不用考...

EasyUI弹窗批量修改combogrid下拉框的值

JS方法//点击弹出批量修改框 UpdateLot:function(){ varrow=$(&quot;#dg&quot;).datagrid(&quot;getChecked&quot;); if(...

js与controller中分割字符串的方法

js: varstr=OpenRule; varstrs=newArray(); strs=str.split(&quot;,&quot;); for(vari=0;i&lt;strs.length;i++){ $(&q...

如何修改cSS中存在的element.style内联样式

改腾讯地图的时候调整了下样式,发现样式一直存在问题,修改style里面的值,一点用都没有,html中这个值还找不到是在哪里出...