代码
去www.21code.com看看吧
http://www.21code.com/codebase/?pos=list&type=search&key=EXCEL帮助看
C:\Program Files\Microsoft Office\Office\2052\VBAXL9.CHM
可能根据您的 Office 版本不同,安装位置不同而不同

解决方案 »

  1.   

    我最近了这方面的研究,已经小有成就,不过是对oracle数据做的,
    如果需要就向[email protected]发信。
    有一点心得:通过EXCEL宏跟踪,可以找到需要的代码。
      

  2.   

    对,用宏 记录一下过程,再去看 VBA 是怎么完成的。
    给你参考一下:
    http://www.csdn.net/expert/topic/653/653881.xml?temp=4.063052E-02
      

  3.   

    csdncb(csdncai) ,如果您发代码给我,100分感谢!
    决不食言!
    [email protected]
    [email protected]
      

  4.   

    要求挺多的,一时也贴不上很多。建议你去看一下帮助VBAXL9.CHM---- 1. Application对象---- Application对象处于Excel对象层次结构的顶层,表示Excel自身的运行环境.---- 2. Workbook对象---- Workbook对象直接地处于Application对象的下层,表示一个Excel工作薄文件.---- 3. Worksheet对象---- Worksheet对象包含于Workbook对象,表示一个Excel工作表.---- 4. Range对象---- Range对象包含于Worksheet对象,表示Excel工作表中的一个或多个单元格.
    你如果想做曲线表,可在Excel中先录好宏,再看看里面VBA的写法,贴到VB中就可用了,不过不是很简洁而已。
      

  5.   

    '把MSCHART导入到EXCEL
    Private Sub Command1_Click()
    Command1.Enabled = False
    Dim i As Integer
    Dim j As Integer
    Dim XlApp As Excel.Application
    Dim xlBook As Excel.Workbook
    Dim xlSheet As Excel.Worksheet
    Set XlApp = CreateObject("Excel.Application")
    XlApp.Visible = True
    Set xlBook = XlApp.Workbooks.Add
    Set xlSheet = xlBook.Worksheets(1)
    For i = 1 To MSChart1.RowCount
    MSChart1.Row = i
    For j = 1 To MSChart1.ColumnCount
    MSChart1.Column = j
    If IsNull(MSChart1.Data) = False Then
    xlSheet.Cells(i + 3, j + 1) = MSChart1.Data
    End If
    Next j
    Next i
    '画曲线
    Range("B4:F8").Select
        Charts.Add
        ActiveChart.ChartType = xlColumnClustered
        ActiveChart.SetSourceData Source:=Sheets("Sheet1").Range("B4:F8"), PlotBy:= _
            xlColumns
        ActiveChart.Location Where:=xlLocationAsObject, Name:="Sheet1"
        With ActiveChart
            .HasTitle = False
            .Axes(xlCategory, xlPrimary).HasTitle = False
            .Axes(xlValue, xlPrimary).HasTitle = False
        End WithEnd SubPrivate Sub Form_Load()
    MSChart1.RowCount = 5
    MSChart1.ColumnCount = 5
    For i = 1 To MSChart1.RowCount
    MSChart1.Row = i
    For j = 1 To MSChart1.ColumnCount
    MSChart1.Column = j
    MSChart1.Data = i * j
    Next j
    Next i
    End Sub
      

  6.   


    首先建立一个窗体(FORM1)在窗体中加入一个DATA控件和一按钮,引用Microsoft Excel类型库:从"工程"菜单中选择"引用"栏;选择Microsoft Excel 8.0 Object Library;选择"确定"。在FORM的LOAD事件中加入:
      Data1.DatabaseName = 数据库名称
      Data1.RecordSource = 表名
      Data1.Refresh在按钮的CLICK事件中加入
      Dim Irow, Icol As Integer
      Dim Irowcount, Icolcount As Integer
      Dim Fieldlen() "存字段长度值
      Dim xlApp As Excel.Application
      Dim xlBook As Excel.Workbook
      Dim xlSheet As Excel.Worksheet  Set xlApp = CreateObject("Excel.Application")
      Set xlBook = xlApp.Workbooks.Add
      Set xlSheet = xlBook.Worksheets(1)  With Data1.Recordset
      .MoveLast  If .RecordCount < 1 Then
        MsgBox ("Error 没有记录!")
        Exit Sub
      End If  Irowcount = .RecordCount "记录总数
      Icolcount = .Fields.Count "字段总数  ReDim Fieldlen(Icolcount)
      .MoveFirst  For Irow = 1 To Irowcount + 1
       For Icol = 1 To Icolcount
      Select Case Irow
      Case 1 "在Excel中的第一行加标题
      xlSheet.Cells(Irow, Icol).Value = .Fields(Icol - 1).Name
      Case 2 "将数组FIELDLEN()存为第一条记录的字段长  If IsNull(.Fields(Icol - 1)) = True Then
        Fieldlen(Icol) = LenB(.Fields(Icol - 1).Name)
         "如果字段值为NULL,则将数组Filelen(Icol)的值设为标题名的宽度
      Else
        Fieldlen(Icol) = LenB(.Fields(Icol - 1))
      End If  xlSheet.Columns(Icol).ColumnWidth = Fieldlen(Icol)
       "Excel列宽等于字段长
      xlSheet.Cells(Irow, Icol).Value = .Fields(Icol - 1)
       "向Excel的CellS中写入字段值
      Case Else
      Fieldlen1 = LenB(.Fields(Icol - 1))  If Fieldlen(Icol) < Fieldlen1 Then
      xlSheet.Columns(Icol).ColumnWidth = Fieldlen1
       "表格列宽等于较长字段长
      Fieldlen(Icol) = Fieldlen1
       "数组Fieldlen(Icol)中存放最大字段长度值
      Else
       xlSheet.Columns(Icol).ColumnWidth = Fieldlen(Icol)
      End If  xlSheet.Cells(Irow, Icol).Value = .Fields(Icol - 1)
      End Select
      Next
      If Irow <> 1 Then
      If Not .EOF Then .MoveNext
      End If
      Next
      With xlSheet
      .Range(.Cells(1, 1), .Cells(1, Icol - 1)).Font.Name = "黑体"
       "设标题为黑体字
      .Range(.Cells(1, 1), .Cells(1, Icol - 1)).Font.Bold = True
       "标题字体加粗
      .Range(.Cells(1, 1), .Cells(Irow, Icol - 1)).Borders.LineStyle = xlContinuous
       "设表格边框样式
      End With
      xlApp.Visible = True '显示表格
      xlBook.Save '保存
      Set xlApp = Nothing '交还控制给Excel
      End With
      

  7.   

    用VB创建复杂表格
     
    ---- 数据库管理系统的开发人员经常感叹的一个问题就是:我们中国人的报表太复杂了!无规则、嵌套、斜线、交叉线等历来都是困挠开发人员的最大问题。设计一个数据库固然有一定的技巧,设计数据操作也固然需要一定的逻辑分析能力,但这些问题对一般的开发人员来说应该是不成为问题的。用户可是不管你采用了多么灵活的算法多么方便的操作,他们最感兴趣的是最后他们出来的报表如何漂亮,出报表的操作如何简单(最好是一个按钮解决所有的问题)。笔者在开发数据库管理系统方面也稍有些经验,从FoxPro、Delphi、PowerBuilder一直到现在用的VB,都遇到过设计打印报表的问题,这些软件在设计报表的过程中可谓各有千秋,我这里不一一细说。我在这里只向大家介绍一种我迄今为止最为满意的一种设计打印报表的方法:利用VB操作EXCEL来生成复杂的报表。---- 一. 用VB创建外部EXCEL对象---- 大多数大型 ActiveX-enabled 应用程序和其它 ActiveX 部件,在它们的对象层次中都提供了一个顶层外部可创建对象。该对象提供了对该层次中其它对象的访问,并且还提供对整个应用程序起作用的方法和属性。---- 例如,每个 Microsoft Office 应用程序提供一个顶层 Application 对象。下面语句显示了对Microsoft Excel的 Application 对象的引用:Dim xlApp As Excel.Application
    Set xlApp = New Excel.Application---- 然后,可以用这些变量来访问在EXCEL应用程序中的从属对象、以及这些对象的属性和方法。例如:Set xlApp = CreateObject("Excel.Application")
    ‘激活EXCEL应用程序
    xlApp.Visible = False ‘隐藏EXCEL应用程序窗口
    Set xlBook = xlApp.Workbooks.Open(strDestination)
    ‘打开工作簿,strDestination为一个EXCEL报表文件
    Set xlSheet = xlBook.Worksheets(1)
    ‘设定工作表---- 二. 用EXCEL 97设计报表的模版文件---- EXCEL 97是一个非常优秀的创建报表的工具。它提供的单元格任意合并、拆分和绘图功能基本上能够满足设计所有复杂报表的需求。它对任意一个单元格的格式随意控制,更为随心所欲地设计报表提供了强大的支持。---- 根据用户提供的报表,我们可以很快在EXCEL里生成模版文件。所谓生成模版文件只是为了满足用户多方面的需求而设计的。也是为了适合报表以后的更改而做的一点预备工作。例如用户需要打印几百张职工履历表,但其格式都是一致的,并且随着时间和实际情况的变化,表格格式有可能需要改变,我们设计一个模版文件显然可以“以不变应万变”了。---- 生成工作表时我们应当记录下要填充内容的单元格编号和该单元格内要填充的数据字段。这样形成一个表格,在写程序时一目了然。如:Cell(4,2) 职工姓名 Cell(6,6) 毕业学校
    Cell(4,4) 职工性别 Cell(6,7) 所学专业
    Cell(4,6) 职工民族 Cell(6,9) 工作时间
    (表一)---- 在程序里我们当然不要对模版文件进行操作了,我们只需要对模版文件的一个拷贝进行操作就行(这也是我们设计模版文件的一个目的和好处)。如下面的例子:Dim strSource, strDestination As String
    strSource = App.Path & "\Excels\RegisterFee.xls" 
    ‘RegisterFee.xls就是一个模版文件
    strDestination = App.Path & "\Excels\Temp.xls" 
    FileCopy strSource, strDestination
    ‘将模版文件拷贝到一个临时文件---- 三. 生成工作表内容---- 有了上述两步工作的铺垫,我们下面接着就只要根据(表一)的格式给各单元格赋值了。如: datPrimaryRS.Recordset.MoveFirst
    ‘datPrimaryRS为Data控件
      If IsNull(datPrimaryRS.Recordset!姓名) = False Then
      xlSheet.Cells(4, 2) = datPrimaryRS.Recordset!姓名
      End If
      If IsNull(datPrimaryRS.Recordset!性别) = False Then
      xlSheet.Cells(4, 4) = datPrimaryRS.Recordset!性别
      End If
      If IsNull(datPrimaryRS.Recordset!民族) = False Then
      xlSheet.Cells(4, 6) = datPrimaryRS.Recordset!民族
      End If
    ………………---- 四. 打印报表---- 生成了工作表后,就可以对EXCEL发出打印指令了。---- 注意在执行打印操作之前应该对EXCEL临时文件执行一次保存操作,以免在退出应用程序后EXCEL还提示用户是否保存已修改的文件,让用户觉得莫名其妙。如下语句:xlBook.Save ‘保存文件
      xlSheet.PrintOut ‘执行打印
      xlApp.Quit ‘退出EXCEL---- 至此读者应该看到,我们设计的报表打印是通过EXCEL程序来后台实现的。用户根本看不到具体过程,他们只看到一张张漂亮的报表轻易地被打印出来了。