0

0

C#将DataView导出到文件 C#如何把筛选和排序后的DataView保存

煙雲

煙雲

发布时间:2026-02-27 11:06:35

|

666人浏览过

|

来源于php中文网

原创

调用 dataview.totable() 可获取已应用筛选与排序的新 datatable;导出 csv 需手动转义特殊字符;导出 excel 需 epplus 或 npoi;导出前须校验 dataview 状态有效性。

c#将dataview导出到文件 c#如何把筛选和排序后的dataview保存

直接用 DataView.ToTable() 获取筛选排序后的数据

DataView 本身不持有独立数据,它只是对底层 DataTable 的视图。但 ToTable() 方法能真正提取当前视图状态(包括 RowFilterSort)下的行,生成一个新 DataTable,这才是可导出的基础。

常见错误是试图直接序列化 DataView 或遍历其 Rows 属性写文件——这会漏掉排序/筛选逻辑,或抛出 NotSupportedException(因为 DataView.Row 是只读投影)。

  • 调用 dataView.ToTable() 即可获得已应用过滤与排序的新表;若只要部分列,用 ToTable(false, "Col1", "Col2")
  • 确保 DataView.SortDataView.RowFilter 已提前设置好,否则导出的是原始顺序和全部行
  • 注意:如果原 DataTable 有计算列或表达式列,ToTable() 会保留其计算结果,但不会重新触发表达式求值(除非原表数据已变更)

导出为 CSV 文件最轻量、兼容性最好

CSV 是最常用且无依赖的导出格式,尤其适合 Excel 打开。关键是正确处理字段中的逗号、换行符和双引号 —— .NET 没有内置安全 CSV 写入器,得手动转义。

别用简单 string.Join(",") 拼接,否则含逗号的单元格会破坏结构;也别依赖第三方库(如 Microsoft.Data.SqlClient 不提供 CSV 导出)。

  • 对每个字段:若含 ," 或换行符(\n),需用双引号包裹,并将内部 " 替换为 ""
  • StreamWriter 配合 Encoding.UTF8,避免中文乱码;首行写列名(可选)
  • 示例关键逻辑:
    foreach (DataRow row in table.Rows) {
        var fields = new List<string>();
        foreach (var item in row.ItemArray) {
            string s = item?.ToString() ?? "";
            if (s.Contains(",") || s.Contains("\"") || s.Contains("\n")) {
                s = $"\"{s.Replace("\"", "\"\"")}\"";
            }
            fields.Add(s);
        }
        writer.WriteLine(string.Join(",", fields));
    }

导出到 Excel(.xlsx)需用 EPPlusNPOI

原生 .NET 不支持写 .xlsx。想免 Office 依赖、高性能导出,EPPlus(v6+ 需商业许可)或开源 NPOI 是主流选择。两者都支持样式、多 Sheet,但 API 差异大。

提客AI提词器
提客AI提词器

「直播、录课」智能AI提词,搭配抖音直播伴侣、腾讯会议、钉钉、飞书、录课等软件等任意软件。

下载

容易踩的坑:用错 NuGet 包名(如 EPPlus vs EPPlus.Core 已废弃)、未设置 License(EPPlus v6+ 报 LicenseException)、忘记调用 Save()

  • NPOI 更轻量,免费,推荐用 NPOI.OpenXml4Net + NPOI.XSSF.UserModel;创建 XSSFWorkbookCreateSheet → 填充行
  • 列宽需手动 sheet.AutoSizeColumn(i),否则 Excel 默认很窄;时间类型要设 CellStyle.DataFormat 否则显示为数字
  • 若导出大数据量(>10 万行),优先用流式写入(NPOI 支持 SXSSFWorkbookEPPlusExcelPackage 流构造函数)

导出前务必检查 DataView 状态是否有效

DataView 可能处于无效状态:比如绑定的 DataTable 被置空、列名拼错导致 Sort 失败(不报错但排序失效)、RowFilter 语法错误(如单引号未闭合)导致过滤为空。

这些都不会在调用 ToTable() 时抛异常,只会静默返回空表或原始数据,导出结果“看起来正常”却不符合预期。

  • 导出前加校验:if (dataView.Count == 0) { /* 提示用户无匹配数据 */ }
  • 检查 dataView.Table.Columns.Contains("xxx") 再设 Sort,避免运行时忽略无效列名
  • RowFilter 字符串建议用参数化拼接(如 $"Name LIKE '{keyword.Replace("'", "''")}%'"),防止 SQL 注入式错误和语法崩溃

导出本质是把 DataView 的当前快照固化下来,关键不在“怎么写文件”,而在于确认你取到的确实是用户看到的那个视图 —— 这一点最容易被跳过。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

1047

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

339

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

379

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1884

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

378

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

1437

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

585

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

437

2024.04.29

html5播放器怎么用
html5播放器怎么用

本合集全面介绍HTML5播放器的使用方法,涵盖基础语法、自定义控制、兼容性处理及实战示例。阅读专题下面的文章了解更多详细内容。

0

2026.02.27

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 10.3万人学习

C 教程
C 教程

共75课时 | 5万人学习

C++教程
C++教程

共115课时 | 19.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号