OpenFileDialog选择文件并获取Excel数据/开窗选择保存路径

2024-04-09 04:08

本文主要是介绍OpenFileDialog选择文件并获取Excel数据/开窗选择保存路径,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

public static System.Data.DataTable ExcelToDatatalbe(int startRow)//导入{OpenFileDialog ofd = new OpenFileDialog();ofd.Filter = "Excel文件|*.xls;*.xlsx";ofd.Title = "选择Excel文件";ofd.Multiselect = false;if (ofd.ShowDialog() == DialogResult.OK){Aspose.Cells.Workbook book = new Aspose.Cells.Workbook();book.Open(ofd.FileName);Aspose.Cells.Worksheet sheet = book.Worksheets[0];Cells cells = sheet.Cells;//获取excel中的数据保存到一个datatable中System.Data.DataTable dt_Import = cells.ExportDataTableAsString(startRow, 0, cells.MaxDataRow + 1, cells.MaxDataColumn + 1, false);// dt_Import.return dt_Import;}elsereturn new System.Data.DataTable();}
/// <summary>/// 从Excel获取数据  NPOI/// </summary>/// <param name="startRow"></param>/// <returns></returns>public static System.Data.DataTable GetExcelData(int startRow, out string msg){#region NPOI方式OpenFileDialog ofd = new OpenFileDialog();ofd.Filter = "Excel文件|*.xls;*.xlsx";ofd.Title = "选择Excel文件";ofd.Multiselect = false;msg = "";if (ofd.ShowDialog() == DialogResult.OK){bool hasTitle = true;string fileName = ofd.FileName;Microsoft.Office.Interop.Excel.Application app = new Microsoft.Office.Interop.Excel.Application();Sheets sheets;object oMissiong = System.Reflection.Missing.Value;Microsoft.Office.Interop.Excel.Workbook workbook = null;System.Data.DataTable data = new System.Data.DataTable();try{if (app == null) return null;workbook = app.Workbooks.Open(fileName, oMissiong, oMissiong, oMissiong, oMissiong, oMissiong,oMissiong, oMissiong, oMissiong, oMissiong, oMissiong, oMissiong, oMissiong, oMissiong, oMissiong);sheets = workbook.Worksheets;//将数据读入到DataTable中Microsoft.Office.Interop.Excel.Worksheet worksheet = (Microsoft.Office.Interop.Excel.Worksheet)sheets.get_Item(1);//读取第一张表 if (worksheet == null) return null;int iRowCount = worksheet.UsedRange.Rows.Count;int iColCount = worksheet.UsedRange.Columns.Count;//生成列头for (int i = 0; i < iColCount; i++){var name = "column" + i;if (hasTitle){var txt = ((Microsoft.Office.Interop.Excel.Range)worksheet.Cells[startRow, i + 1]).Text.ToString();if (!string.IsNullOrEmpty(txt)) name = txt;}while (data.Columns.Contains(name)) name = name + "_1";//重复行名称会报错。data.Columns.Add(new DataColumn(name, typeof(string)));}//生成行数据Microsoft.Office.Interop.Excel.Range range;int rowIdx = hasTitle ? 2 : 1;for (int iRow = rowIdx; iRow <= iRowCount; iRow++){DataRow dr = data.NewRow();for (int iCol = 1; iCol <= iColCount; iCol++){range = (Microsoft.Office.Interop.Excel.Range)worksheet.Cells[iRow, iCol];dr[iCol - 1] = (range.Value2 == null) ? "" : range.Text.ToString();}data.Rows.Add(dr);}}catch (Exception ex){ExceptionUtil.DataCL_HTTP(ex, "", "", FileUtil.GetCurSourceFileName());msg = ex.Message;return null;}finally{workbook.Close(false, oMissiong, oMissiong);System.Runtime.InteropServices.Marshal.ReleaseComObject(workbook);workbook = null;app.Workbooks.Close();app.Quit();System.Runtime.InteropServices.Marshal.ReleaseComObject(app);app = null;}return data;}#endregionreturn null;}
//选择文件夹
FolderBrowserDialog folderBrowserDialog = new FolderBrowserDialog();
if (folderBrowserDialog.ShowDialog(this) == DialogResult.OK)
{string FolderName = folderBrowserDialog.SelectedPath;
}

 

这篇关于OpenFileDialog选择文件并获取Excel数据/开窗选择保存路径的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/887141

相关文章

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

Python进行JSON和Excel文件转换处理指南

《Python进行JSON和Excel文件转换处理指南》在数据交换与系统集成中,JSON与Excel是两种极为常见的数据格式,本文将介绍如何使用Python实现将JSON转换为格式化的Excel文件,... 目录将 jsON 导入为格式化 Excel将 Excel 导出为结构化 JSON处理嵌套 JSON:

python设置环境变量路径实现过程

《python设置环境变量路径实现过程》本文介绍设置Python路径的多种方法:临时设置(Windows用`set`,Linux/macOS用`export`)、永久设置(系统属性或shell配置文件... 目录设置python路径的方法临时设置环境变量(适用于当前会话)永久设置环境变量(Windows系统

Python获取浏览器Cookies的四种方式小结

《Python获取浏览器Cookies的四种方式小结》在进行Web应用程序测试和开发时,获取浏览器Cookies是一项重要任务,本文我们介绍四种用Python获取浏览器Cookies的方式,具有一定的... 目录什么是 Cookie?1.使用Selenium库获取浏览器Cookies2.使用浏览器开发者工具

Java获取当前时间String类型和Date类型方式

《Java获取当前时间String类型和Date类型方式》:本文主要介绍Java获取当前时间String类型和Date类型方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录Java获取当前时间String和Date类型String类型和Date类型输出结果总结Java获取

C#监听txt文档获取新数据方式

《C#监听txt文档获取新数据方式》文章介绍通过监听txt文件获取最新数据,并实现开机自启动、禁用窗口关闭按钮、阻止Ctrl+C中断及防止程序退出等功能,代码整合于主函数中,供参考学习... 目录前言一、监听txt文档增加数据二、其他功能1. 设置开机自启动2. 禁止控制台窗口关闭按钮3. 阻止Ctrl +

java如何实现高并发场景下三级缓存的数据一致性

《java如何实现高并发场景下三级缓存的数据一致性》这篇文章主要为大家详细介绍了java如何实现高并发场景下三级缓存的数据一致性,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 下面代码是一个使用Java和Redisson实现的三级缓存服务,主要功能包括:1.缓存结构:本地缓存:使

在MySQL中实现冷热数据分离的方法及使用场景底层原理解析

《在MySQL中实现冷热数据分离的方法及使用场景底层原理解析》MySQL冷热数据分离通过分表/分区策略、数据归档和索引优化,将频繁访问的热数据与冷数据分开存储,提升查询效率并降低存储成本,适用于高并发... 目录实现冷热数据分离1. 分表策略2. 使用分区表3. 数据归档与迁移在mysql中实现冷热数据分

C#解析JSON数据全攻略指南

《C#解析JSON数据全攻略指南》这篇文章主要为大家详细介绍了使用C#解析JSON数据全攻略指南,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、为什么jsON是C#开发必修课?二、四步搞定网络JSON数据1. 获取数据 - HttpClient最佳实践2. 动态解析 - 快速