关于Excel导入的问题记录

当Excel导入成为需要时,之前的导出Excel为html方式的方法就受阻了,于是,需要开始新的百度与google来解决问题。

前提为OLEDB+Excel。

根据需求,多数是对于表的数据的导入。于是产生这么一个需求过程:

1。准备一个空的标准Excel。

2。根据表名查询字段

3。动态生成字段表头

4。Copy空的标准Excel,循环表头生成新的标准Excel以二进制流导出。

5。用户再根据表头的提示添加数据再上传提交。

(1步和4步为大体上为网上搜出来的想法)

过程遇到这么点问题:

问题1:

网上1步和4步的想法,是先做好标准Excel,直接导出。所以代码上用的insert into table直接往表添加数据了。

于本人的需求有点差距了,异常折腾了半天才折腾到用了Create Table。于是引发了第二个问题:

问题2:

在为Excel Create Table 时,报“不能修改表'xxxx' 的设计。它在只读数据库中”,经自己这么一想,再经网上那么一忽悠。权限问题!。for遍了网络,都直指这个权限问题。

于是就是一堆的往文件夹添加IUser_用户名或EveryOne权限的解决方案,是挺折磨人的,检查了N百遍还是报的错。

最后在某处看到一条关于数据链接链接的解释如下:

 


代码

如果把Excel看作数据库,那么要注意连接字符串:

private readonly string readConn = "Provider=Microsoft.Jet.OLEDB.4.0;" +"Data Source={0};"

              +"Extended Properties='Excel 8.0;HDR=YES;IMEX=1;'";

HDR=YES 表示将sheet的第一行作为列名,所以我们默认excel的首行是列名。

IMEX=1 表示大致的意思是使用导入的模式,把数字也作为字符串来操作。

    有一点很重要。IMEX=1,是一种导入的模式,所以首先这个文件要存在,如果不存在会报错:“Microsoft Jet 数据库引擎找不到对象'…\Customer.xls'。请确定对象是否存在,并正确地写出它的名称和路径”,而且这样写了以后就算文件是存在的,还有一个问题是不能对文件更新的,会提示“不能修改表 'sheet1' 的设计。它在只读数据库中”等错误,甚至还有提示权限的问题。

 

于是去掉IMEX=1,问题解决。

于是问题3也产生了:

新建的表默认都排在最后了,无法排在第一个,这样用户打开看到空的就不好,于是drop table xxx---》无效

忽悠下自己是不是方法不对头,上网搜。于是又发现这么段说明:

 


代码

虽然 Jet OLE DB 提供程序允许您在 Excel 工作簿中插入和更新记录,但是不允许进行 DELETE(删除)操作。如果您尝试对一个或多个记录执行 DELETE 操作,您将收到以下错误信息: 
Deleting data in a linked table is not supported by this ISAM.

这是将 Excel 工作簿作为数据库进行处理时所固有的限制。

 

于是,想了一个比较搜的主意

在空的Excel里删除两个Sheet(默认有三个,系统限制必须存在一个)

然后将剩下的一个改名叫“xxx说明",在里面写操作说明。

 

至此,将就解决,还有很多工作排成队在后面......

时间: 2024-08-03 02:05:25

关于Excel导入的问题记录的相关文章

从VB中的Datagride中向excel导入数据

datagrid|excel|导入数据   程序需要我在网上找了很久才找到刚刚把程序写好并加写了注释希望能帮助大家再写程序前先引用microsoft excel 11.0 object Library我看到的文章是10.0的我这是office2003是11.0只要安了excel就有这个引用~Private Sub cmdsave_Click()MsgBox "文件保存为: D:\电网配电线路管理信息系统\信息查询结果\事故信息查询结果.xls"    Dim i As Integer 

应用宝导入/导出通话记录、联系人和短信有几种格式?如何操作?

  1.导入/导出通话记录只有xml一种格式,在"我的手机=>通讯录=>通话记录"模块就可以选择对全部或部分通话记录的导入/导出. 2.导入/导出联系人有Xml.Outlook.vCard.CSV.Excel五种格式,在"我的手机=>通讯录"模块就可以选择对全部或部分联系人的导入/导出. 3.导入/导出短信只有Xml一种种格式,在"我的手机=>短信"模块就可以选择对全部或部分短信的导入/导出.

sql2005-急求大师解决 excel导入到SQL2005 问题

问题描述 急求大师解决 excel导入到SQL2005 问题 50C const BeginRow = 2; BeginCol = 1;var Excel: OleVariant; iRowiCol : integer; xlsFilename: string; filename:string; iExcelRowCountOkNumFailNum:integer; begin inherited; begin OpenDialog1.Title := '请选择相应的Excel文件'; Open

oledb 连接串的格式-Excel导入数据库的 OleDb 连接串的格式,发生错误:找不到可安装的 ISAM。

问题描述 Excel导入数据库的 OleDb 连接串的格式,发生错误:找不到可安装的 ISAM. Excel导入数据库的 OleDb 连接串的格式,发生错误:找不到可安装的 ISAM. FILEname = "EXCEL" + DateTime.Now.ToString("yyyyMMddHHmmssfff") + up[up.Length - 1]; File1.PostedFile.SaveAs(Server.MapPath(@"/exceltest/

excel导入导出问题ooo11

问题描述 咨询一下各位大虾,我在做excel导入导出的时候,总数不成功,麻烦帮忙指教啊,谢谢了.代码如下:///<summary>///将DataSet数据导出到Excel,DataSet数据从数据库读取///</summary>///<paramname="ds">DataSet数据源</param>publicvoidExportToExcel(DataSetds){//TbBindData是一个集合,通过excel导入进来intin

Excel导入数据库

问题描述 各位大虾,小弟小弟现在有个"重大"问题,望各位出手帮助???先谢过了...本地有个几十M的Excle,当然有列头,数据有一定的形式,现在需要统计其中重复的记录,并找出重复的行号?本人的设想是先将数据直接导入数据库,然后根据数据库查询的特征,进行判断统计.现在我使用jcom解析excel(poi.jxl均通过测试,无法解析太大的Excle),获取每行,然后插入数据库,可是,事与愿违,数据是一行一行写入(insert),但是那个速度!!!!不敢恭维,前台一直处于等待中....所以

Excel导入数据库的一个小问题,请教高手

问题描述 在将Excel导入数据库时,数据库里那一列是整型的,我是用Convert.ToInt16(myDrv[2].ToString().Trim())将Excel中的字符转化为整形.但是在Excel中写入时,如果写得不规范,会存成左上角带着绿色小三角的情况,这时就会产生导入异常.请问如何解决? 解决方案 解决方案二:用户可能的输入太多要么规范Excel,要么捕获异常,记录并做相应处理解决方案三:可是我不知道怎么捕获这个异常,总得有个异常码是吧?引用1楼的回复: 用户可能的输入太多要么规范Ex

java实现excel导入数据的工具类_java

导入Excel数据的工具类,调用也就几行代码,很简单的. 复制代码 代码如下: import jxl.Cell;import jxl.Sheet;import jxl.Workbook;import jxl.read.biff.BiffException;import org.apache.commons.beanutils.BeanUtils;import org.slf4j.Logger;import org.slf4j.LoggerFactory; import java.io.IOExc

利用C#实现Excel导入、导出实例教程

1. 介绍 1.1 第三方类库:NPOI 说明:NPOI是POI项目的.NET 版本,可用于Excel.Word的读写操作. 优点:不用装Office环境. 下载地址:http://npoi.codeplex.com/releases 1.2 Excel结构介绍 工作簿(Workbook):每个Excel文件可理解为一个工作簿. 工作表(Sheet):一个工作簿(Workbook)可以包含多个工作表. 行(row):一个工作表(Sheet)可以包含多个行. 2. Excel导入 2.1 操作流程