Linq语法判断DataTable某一列的数据格式

 //求最后一个不为空值的索引

int indexLast = dataTableWorksheet.AsEnumerable().Select(x => x[indexSpecMax].ToString()).ToList().FindLastIndex(m => !string.IsNullOrEmpty(m));

//判断列数据格式,返回bool类型List

 List<bool> resultList = dataTableWorksheet.AsEnumerable()
  .Select(x => x[indexSpecMax].ToString())                     // 转List<string>
  .Select((value, index) => new { value, index })              // (值,索引)形式
  .Where((value, index) =>  index <= indexLast)             // 索引范围选择
  .Select(x => x.value)                                                     // 返回(值)的形式
  .Where(x => !string.IsNullOrEmpty(x))                         // 筛除空值
  .Select(x => double.TryParse(x, out _))                       // double 类型判断
  .ToList();

//反馈给用户提示信息

 if (resultList.Contains(false))
 {
       switch (Program.language)
      {
          case "zh-CN":
          MessageBox.Show("规格值类型错误,请确认!", "信息提示:");
          break;
          default:
          MessageBox.Show("SpecMax data type error", "Information:");
          break;
       }
       return false;
 }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值