Excel导出到DataSet
#region 导入excel 返回Dataset
        public DataSet ExecleDataSet(string filename, string file, string Type)
        {
            string strConn = "";
            if (Type.Equals(".xlsx"))
            {
                strConn = "Provider=Microsoft.Ace.OleDb.12.0;Data Source=" + filename +
                          ";Extended Properties='Excel 12.0 Xml; HDR=YES; IMEX=1'";
            }
            else
            {
                strConn = "Provider=Microsoft.Jet.OleDb.4.0;" + "data source=" + filename +
                          ";Extended Properties='Excel 8.0; HDR=YES; IMEX=1'";
            }
            OleDbConnection conn;
            DataSet ds = new DataSet();
            conn = new OleDbConnection(strConn);
            conn.Open();
            //OleDbDataAdapter odda = new OleDbDataAdapter("select * from [Sheet1$]", conn);
            //odda.Fill(ds, file);
OleDbDataAdapter myCommand = null;
            DataTable dt = new DataTable();
//返回Excel的架构,包括各个sheet表的名称,类型,创建时间和修改时间等  
            DataTable dtSheetName = conn.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, new object[] { null, null, null, "Table" });
//包含excel中表名的字符串数组
            string[] strTableNames = new string[dtSheetName.Rows.Count];
            for (int k = 0; k < dtSheetName.Rows.Count; k++)
            {
                strTableNames[k] = dtSheetName.Rows[k]["TABLE_NAME"].ToString();
                if (strTableNames[k].IndexOf("$") != -1)
                {
                    string strExcel = "select * from [" + strTableNames[k] + "]";
                    myCommand = new OleDbDataAdapter(strExcel, conn);
                    myCommand.Fill(ds, strTableNames[k]);
                }
            }
            conn.Close();
            return ds;
        }
        #endregion
if (FileUpload1.HasFile)
            {
                if (FileUpload1.PostedFile.ContentLength < 1000000000)
                {
                    string isxls = "";
                    string fistName = "";
                    string savePath = "";
                    string strdt = "";
                    DataTable dt;
                    try
                    {
                        isxls = System.IO.Path.GetExtension(FileUpload1.FileName).ToString().ToLower();
                        fistName = System.IO.Path.GetFileName(FileUpload1.FileName).ToString();
                        //if (isxls != ".xls") { Label1.Text = "出现异常:请选择正确的Excel文件!"; return; } //检查文件是不是Excel
                        //文件名组装
                        strdt = DateTime.Now.ToString("yyyyMMddHHmmss") + ".xls";
                        //获取路径
                        savePath = Server.MapPath("/Upload/" + strdt);
                        //文件移动到指定位置
                        FileUpload1.PostedFile.SaveAs(savePath);
                    }
                    catch
                    {
                        lab_message.Text = Resources.global1.teap_errorupload;
                    }
                    try
                    {
                        DataSet ds=ExecleDataSet(savePath, strdt, isxls);
Excel导出到DataSet的更多相关文章
- 使用OpenXml把Excel中的数据导出到DataSet中
		
public class OpenXmlHelper { /// <summary> /// 读取Excel数据到DataSet中,默认读取所有Sheet中的数据 /// </sum ...
 - c#关于EXCEL导出数据库的做法
		
using System;using System.Diagnostics;using System.Collections;using System.Data;using System.Web;us ...
 - 数据库数据用Excel导出的3种方法
		
将数据库数据用Excel导出主要有3种方法:用Excel.Application接口.用OleDB.用HTML的Tabel标签 方法1——Excel.Application接口: 首先,需要要Exce ...
 - 自定义分页Gridview中Excel导出
		
先上图,如图所示导出所有查询出的数据 用的是AspNetPager分页控件,这个导出方法,不受分页和gridview列中数据的约束,可以导出您想导出的数据 首先前台页面代码,lblink即为导出exc ...
 - [moka同学笔记]PHPexcel之excel导出和导入
		
原案例来自http://www.sucaihuo.com/有修改 1.目录结构(文件不用解释,应该都可以看得懂,直接看代码)
 - 偷懒小工具 - Excel导出公共类
		
说明 最近接了一个任务,就是做一个列表的Excel导出功能.并且有很多页面都会使用这个功能. 导出的Excel大体格式如图 很简单的列表,标题加背景色,然后不同类型,显示方式不一样.对齐方式不一样.不 ...
 - 转:POI操作Excel导出
		
package com.rd.lh.util.excel; import java.beans.PropertyDescriptor; import java.io.FileOutputStream; ...
 - TP5.0源生Excel导出
		
PHPExcel类在TP5里边并不能很好的兼容,使用起来很麻烦. 不像是tp3.2那样直接import()加进来就能new,因为它里边的命名空间找不到.总是说undefined class. 如果是使 ...
 - java反射学习之二万能EXCEL导出
		
一.EXCEL导出的实现过程 假设有一个对象的集合,现在需要将此集合内的所有对象导出到EXCEL中,对象有N个属性:那么我们实现的方式是这样的: 循环这个集合,在循环集合中某个对象的所有属性,将这个对 ...
 
随机推荐
- 李宏毅机器学习--PM2.5预测
			
一.说明 给定训练集train.csv,要求根据前9个小时的空气监测情况预测第10个小时的PM2.5含量. 训练集介绍: (1).CSV文件,包含台湾丰原地区240天的气象观测资料(取每个月前20天的 ...
 - 【EditPlus】参数设置
			
1. 设置javac,java快捷键 工具-参数设置-工具-用户工具 组和工具项-组名,更改组名为“java” 添加工具 javac 菜单文字:javac 命令:安装java的javac.exe的绝对 ...
 - 01-复杂度2 Maximum Subsequence Sum
			
01-复杂度2 Maximum Subsequence Sum (25分) 时间限制:200ms 内存限制:64MB 代码长度限制:16kB 判题程序:系统默认 作者:陈越 单位:浙江大学 htt ...
 - Spring LDAP的使用
			
LDAP入门http://www.jianshu.com/p/7e4d99f6baaf Spring LDAP,是Spring的一个组件,实现对LDAP的操作. 在编程操作MySQL时,我们除了用JD ...
 - 【K8S】基于单Master节点安装K8S集群
			
写在前面 最近在研究K8S,今天就输出部分研究成果吧,后续也会持续更新. 集群规划 IP 主机名 节点 操作系统版本 192.168.175.101 binghe101 Master CentOS 8 ...
 - MySQL分页查询的性能优化
			
MySQL limit分页查询的性能优化 Mysql的分页查询十分简单,但是当数据量大的时候一般的分页就吃不消了. 传统分页查询:SELECT c1,c2,cn… FROM table LIMIT n ...
 - Python的内存管理和垃圾回收
			
内存管理 与Python对象创建相关的结构体 #define _PyObject_HEAD_EXTRA \ struct _object *_ob_next; \ struct _object *_o ...
 - 题目分享L
			
题意:n个人围成一个环,每个人初始有一些金币,每个人可以把金币递给相邻的人,问最少传递多少金币使每个人金币数相同? 分析:首先在保证最优的情况下不可能会出现相邻的两个人互相送金币,因为这样他们公共的部 ...
 - java制作甘特图
			
今日来做一下甘特图.网上搜到了这个源码,但是导的jar包,并没有给我.swiftganttdemo但是名为swiftgantt制作:所以灵机一动在网上搜到了swiftangantt组件:在组件中找到了 ...
 - 给你的Java程序拍个片子吧:jstack命令解析
			
前言 如果有一天,你的Java程序长时间停顿,也许是它病了,需要用jstack拍个片子分析分析,才能诊断具体什么病症,是死锁综合征,还是死循环等其他病症,本文我们一起来学习jstack命令~ jsta ...