06毕业设计 - VB导出Excel文档

Private Sub xlsout1_Click()         '导出Excel文档
  If rs1.RecordCount < 1 Then
  MsgBox "导出失败,当前列表中没有记录!"
  outstate1.Visible = False
    Exit Sub
  End If

On Error GoTo not_installexcel '当电脑没装excel软件时的出错处理
If MsgBox(Chr(13) + "是否将当前列表中的数据导出为EXCEL数据?  ", vbQuestion + vbYesNo) = vbNo Then Exit Sub

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
main.Enabled = False
outstate1.Visible = True '显示导出状态
outstate1.Caption = "正在导出,请稍后..."

Set xlApp = CreateObject("Excel.Application")
Set xlBook = xlApp.Workbooks.Add
Set xlSheet = xlBook.Worksheets(1)
With rs1
  .MoveLast
  iRowCount = .RecordCount '记录总数
  iColCount = .Fields.Count '字段总数
  ReDim FieldLen(iColCount)
  .MoveFirst
 
  '写入标头
  xlSheet.Rows(1).RowHeight = 35
  xlSheet.Range(xlSheet.Cells(1, 1), xlSheet.Cells(1, rs1.Fields.Count)).MergeCells = True
  xlSheet.Cells(1, 1).Font.Size = 14
  xlSheet.Cells(1, 1).Font.Bold = True
  If usetype = "系统管理员" Then
     xlSheet.Cells(1, 1).Value = "课时津贴明细列表"
  Else
     xlSheet.Cells(1, 1).Value = usepart & "课时津贴明细列表"
  End If
  '写入记录
  For iRow = 2 To iRowCount + 2
    For iCol = 1 To iColCount
      Select Case iRow
      Case 2 '在Excel中的第一行加标题
        xlSheet.Cells(iRow, iCol).Value = .Fields(iCol - 1).Name
      Case 3 '将数组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
        If FieldLen(iCol) < LenB(.Fields(iCol - 1).Name) Then '如果字段值的长度小于标题名的宽度,则将数组Filelen(Icol)的值设为标题名的宽度
          FieldLen(iCol) = LenB(.Fields(iCol - 1).Name)
        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
      DoEvents
    Next iCol
    If iRow > 2 Then
      If Not .EOF Then .MoveNext
    End If
    DoEvents
    outstate1.Caption = "正在导出,完成: " + CStr(Int(100 * (iRow - 2) / iRowCount)) + "%" '显示导出进度
  Next iRow
  '添加年月日
    xlSheet.Cells(iRowCount + 3, iColCount).Value = Format$(Now, "yyyy年mm月dd日") '在最后一行后加是年月日
    xlSheet.Range(xlSheet.Cells(iRowCount + 3, 1), xlSheet.Cells(iRowCount + 3, iColCount)).MergeCells = True '合并年月日所在的行
    xlSheet.Cells(iRowCount + 3, 1).HorizontalAlignment = xlHAlignRight '设置为右对齐
 
  With xlSheet
    .Range(.Cells(2, 1), .Cells(2, iCol - 1)).Font.Bold = True  '标题字体加粗
    .Range(.Cells(1, 1), .Cells(iRow, iCol - 1)).Borders.LineStyle = xlContinuous   '设表格边框样式
    .Columns("A:I").VerticalAlignment = xlVAlignCenter  '垂直居中
    .Range(.Cells(1, 1), .Cells(iRow - 1, iCol - 1)).HorizontalAlignment = xlHAlignCenter   '水平居中对齐
  End With
  .MoveFirst
  xlApp.Visible = True '显示表格
  Set xlApp = Nothing '交还控制给Excel
End With
outstate1.Visible = False
main.Enabled = True
Exit Sub

not_installexcel:  '当电脑没有装excel软件时的处理
    MsgBox "导出错误!请检查电脑是否装有不低于Excel2000版本的Excel软件!" & Chr(13) & Chr(10) & "然后检查一下出错处的记录是否有问题!"
    outstate1.Visible = False
    main.Enabled = True
End Sub

posted @ 2009-06-08 09:04  栢芯  阅读(749)  评论(0编辑  收藏  举报