odbc好像不能联excel
可以先在access中连接一个,然后用odbC联这个access就可以实现操作excel.

解决方案 »

  1.   

    用ODBC数据库技术存取Excel ---- ODBC就是开放式数据库链接标准,不同种类的数据库只需提供各自的ODBC 驱动程序就可按相同的命令操纵,微软同样为Excel提供了ODBC驱动程序,我们可在程序中象数据库一样存取Excel表格。定义好ODBC数据源后,实际试验中并没有如想象的那样简单,在控件Table的属性TableName中总是检索不到表名,同样也没有相关的资料可供查阅。通过对Excel的分析,终于发现了问题的关键所在:ODBC的表名并不就是Excel的工作表名(如Sheet1),在Excel 表格中必须对要求操作的行列区域定义一个“名称”作为数据库的表名,该区域的首行各列必须是字段名(否则首行数据会当成字段名),可以定义多个表名。具体操作步骤如下: ---- 1.在Excel上定义“表名”: ---- 运行Excel程序,打开或新建一表格,按下鼠标左键选择一片区域(起始行先填上字段名),再将鼠标位置点到左上角的地址栏,输入一表名如ABC,或者在菜单上选:“插入(I)”-“名称(N)”-“定义(D)”,再输入表名(若已定义, 可在此处删除掉),存盘退出(假定文件名取为c:\Book.xls),若嫌字段名行多余,存盘前可隐藏掉; ---- 2.定义ODBC数据源: ---- 从Windows桌面“我的电脑"进入“控制面板”,双击“32位ODBC”图标,运行“用户DSN”中的“添加(D)"后选“Excel Driver(*.xls)", 再点“完成”便弹出对话框,在“数据源名(N)"右边填一名称,如:excel01,在“版本(V)"上选“Excel97", 点中“选项”取消“只读”,在“选定工作目录”中,选定Excel文件名(本例 c:\Book1.xls),再点“确定”直至退出; ---- 3.设置Database控件避免登录检查: ---- 运行C++Builder,在Form1中加上Data Access的三个控件:Database1、 DataSource1、Table1,加入Database1的目的是为了避免打开数据库时出现登录框,为此双击此控件弹出一对话框,在Alias name中选ODBC数据源名(本例为Excel01),在Name中填上一新的别名(本例取Excel02),再点“Defaults” 出现一批参数缺省值,最后取消Options中的两项“Login prompt"与"Keep inactive connect”,点OK退出; ---- 4.设置其它控件属性: ---- 将Table1的属性DatabaseName选为步骤3中的新别名Excel02,再将另一属性TableName选为步骤1的表名(本例为ABC);将控件DataSource1的属性 DataSet选为Table1;双击Form1,在FormCreate事件子程序内加上一句 Table1- >Open( ); ---- 5.查看数据库内容: ---- 为了直接看到Excel数据,在Form1中再加上Data Controls的控件DBGrid1 和DBNavigator1,将两者的属性DataSource都选为DataSource1,双击Table1 的属性Active将值改为true,等待数秒就可看到DBGrid1中出现数据,最后恢复Tabel1- >Active为false; ---- 注意:程序编译前,必须将刚打开的表关闭,即:使Table1- >Active为false, 否则程序运行时报告出错,因为Excel表总是被ODBC以“独占”方式打开;
      

  2.   

    那么要怎么做才行呢?我记得可以用odbc直接连excel的啊。至少可以从里面读数据吧。
      

  3.   

    1.在EXCEL中, 是不需要conncetion, 应该这样写
       Dim xlconn As String
       Dim xlrs As New ADODB.Recordset
       Dim xlFile As String
       Dim xlSheet as string   xlFile = "c:\a.xls"
       xlSheet = "sheet1"   xlconn = "DRIVER=Microsoft Excel Driver (*.xls);" & "DBQ=" & xlFile
       xlrs.Open "select * from [" & xlSheet & "$]", xlconn
      

  4.   

    谢谢wpoplar(sheep) 的帮助。
    我现在已经可以用odbc打开excel文件了。那么我想知道,如何自动得到第一个sheet的名字并打开呢?还有我需要打开不是从第一行开始的数据,怎么做到?
      

  5.   

    Sub Get_Data()
      
      Dim OraSession As Object
      Dim OraDatabase As Object
      Dim EmpDynaset As Object
      Dim ColNames As Object
      
      Set OraSession = CreateObject("OracleInProcServer.XOraSession")
      Set OraDatabase = OraSession.OpenDatabase("ExampleDb", "scott/tiger", 0&)
      Set EmpDynaset = OraDatabase.DbCreateDynaset("select * from emp", 0&) Set ColNames = EmpDynaset.Fields  
      For icols = 1 To ColNames.Count
        Worksheets("DataSheet").Cells(1, icols).Value = ColNames(icols - 1).Name
      Next
         
      EmpDynaset.CopyToClipboard -1
      Sheets("DataSheet").Select
      Range("A2").Select
      ActiveSheet.Paste
      
    End Sub这是ORACLE提供的OO4O使用EXCEL与ORACLE数据库的例子.
      

  6.   

    2. Dim tempxlApp As New Excel.Application
       tempxlApp.Workbooks.Open("c:\a.xls").Worksheets(1).Name
    3. 这个与SQL的取法是一样的,因为是RECORDSET, 第几行也就是第几条记录而已,
       N = xlrs.RecordCountOK,现学现卖,给分吧.
      

  7.   

    楼上的代码可能有问题吧。 应该是到RecordCount-1吧。