如何使用C#读取Excel文件既不使用Interop也不使用OpenXML [英] How to read an Excel file using c# neither using Interop nor OpenXML

查看:96
本文介绍了如何使用C#读取Excel文件既不使用Interop也不使用OpenXML的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述





我想用C#读取excel文件,但是



1.我不想使用Interop,因为微软本身建议不要使用各种问题的bcoz

2.我也不想使用OpenXML,因为我的文件将受密码保护,OpenXML不支持< br $>




请建议除此以外的任何其他创意。

解决方案

您好我正在使用 NPOI 项目来处理excel文件


您好Mathi,试试这个;



 IExcelDataReader iExcelDataReader =  null ; 

FileStream oStream = File.Open(filepath,FileMode.Open,FileAccess.Read);

iExcelDataReader = ExcelReaderFactory.CreateOpenXmlReader(oStream);

iExcelDataReader.IsFirstRowAsColumnNames = true ;

DataSet dsUnUpdated = new DataSet();

dsUnUpdated = iExcelDataReader.AsDataSet();

iExcelDataReader.Close();

if (dsUnUpdated == null
{
oStream = File.Open(filepath,FileMode.Open,FileAccess.Read);
iExcelDataReader = ExcelReaderFactory.CreateBinaryReader(oStream);

iExcelDataReader.IsFirstRowAsColumnNames = true ;

dsUnUpdated = iExcelDataReader.AsDataSet();

iExcelDataReader.Close();
}





你需要为此添加命名空间;



 使用 System.Runtime.Serialization.Formatters.Binary; 





我希望这会对你有所帮助。



谢谢



Mohan G


Hi,

I want to Read an excel file using C# but

1. I dont want to use Interop since microsoft itself advises not to use that bcoz of various problems
2. I dont want to use OpenXML also since my file will be password protected, which will not be supported by OpenXML


Please suggest any other Idea other than this.

解决方案

Hi I'm using NPOI project in order to process excel files


Hi Mathi, try this;

IExcelDataReader iExcelDataReader = null;
 
            FileStream oStream = File.Open(filepath, FileMode.Open, FileAccess.Read);
 
            iExcelDataReader = ExcelReaderFactory.CreateOpenXmlReader(oStream);
 
            iExcelDataReader.IsFirstRowAsColumnNames = true;
 
            DataSet dsUnUpdated = new DataSet();
 
            dsUnUpdated = iExcelDataReader.AsDataSet();
 
            iExcelDataReader.Close();
 
            if (dsUnUpdated == null)
            {
                oStream = File.Open(filepath, FileMode.Open, FileAccess.Read);
                iExcelDataReader = ExcelReaderFactory.CreateBinaryReader(oStream);
 
                iExcelDataReader.IsFirstRowAsColumnNames = true;
 
                dsUnUpdated = iExcelDataReader.AsDataSet();
 
                iExcelDataReader.Close();
            }



you need to add Namespace for this;

using System.Runtime.Serialization.Formatters.Binary;



I hope this will help you.

Thank's

Mohan G


这篇关于如何使用C#读取Excel文件既不使用Interop也不使用OpenXML的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆