vb.net datagridview匯出到excel表

來源:互聯網
上載者:User

Public Function ExportXLsD(ByVal datagrid As DataGrid) ', ByVal Title As String)
  'Dim Mytable As New DataTable
  'Mytable = CType(datagrid.DataSource, DataTable)
  If mytable Is Nothing Then
    MessageBox.Show("沒有記錄不能匯出資料", "PurpleStar", MessageBoxButtons.OK, MessageBoxIcon.Information)
    Exit Function
  End If
  If mytable.Rows.Count > 0 Then
    Dim MyFileName As String
    Dim FileName As String
    With SaveFileDialog1
     .AddExtension = True '如果使用者忘記添加副檔名,將自動家上
     .DefaultExt = "xls" '預設副檔名
     .Filter = "Excel檔案(*.xls)|*.xls"
     .Title = "檔案儲存到"
     If .ShowDialog = DialogResult.OK Then
     FileName = .FileName
     End If
    End With
    MyFileName = Microsoft.VisualBasic.Right(FileName, 4)
    If MyFileName = "" Then
     Exit Function
    End If
    If MyFileName = ".xls" Or MyFileName = ".XLS" Then
     Dim FS As FileStream = New FileStream(FileName, FileMode.Create)
     Dim sw As StreamWriter = New StreamWriter(FS, System.Text.Encoding.Default)
     sw.WriteLine(vbTab & FileName & vbTab & Date.Now)
     Dim i, j As Integer
     Dim str As String = ""
     For i = 0 To mytable.Columns.Count - 1
     str = mytable.Columns(i).Caption
     sw.Write(str & vbTab)
     Next
     sw.Write(vbCrLf)
     For j = 0 To mytable.Rows.Count - 1
     For i = 0 To mytable.Columns.Count - 1
      Dim strColName, strRow As String
      strRow = IIf(mytable.Rows(j).Item(i) Is DBNull.Value, "", mytable.Rows(j).Item(i))
      sw.Write(strRow & vbTab)
     Next
     sw.Write(vbLf)
     Next
     sw.Close()
     FS.Close()
     MessageBox.Show("資料匯出成功!", "PurpleStar", MessageBoxButtons.OK, MessageBoxIcon.Information)
    Else
     Exit Function
    End If
  Else
    MessageBox.Show("沒有記錄不能匯出資料", "PurpleStar", MessageBoxButtons.OK, MessageBoxIcon.Information)
  End If
  End Function
  Private Sub OK_Button_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles OK_Button.Click
  Dim saveExcel As SaveFileDialog
  saveExcel = New SaveFileDialog
  saveExcel.Filter = "Excel檔案(.xls)|*.xls"
  Dim filename As String
  If saveExcel.ShowDialog = Windows.Forms.DialogResult.Cancel Then Exit Sub
  filename = saveExcel.FileName
  Dim excel As Excel.Application
  excel = New Excel.Application
  excel.DisplayAlerts = False
  excel.Workbooks.Add(True)
  excel.Visible = False
  Dim i As Integer
  For i = 0 To DataGridView1.Columns.Count - 1
    excel.Cells(1, i + 1) = DataGridView1.Columns(i).HeaderText
  Next
  '設定標題
  Dim j As Integer
  For i = 0 To DataGridView1.Rows.Count - 1 '填充資料
    For j = 0 To DataGridView1.Columns.Count - 1
     excel.Cells(i + 2, j + 1) = DataGridView1(j, i).Value
    Next
  Next
  excel.Workbooks(1).SaveCopyAs(filename) '儲存
  Me.Close()
  End Sub

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.