Экспорт Gridview в Excel со строками, отформатированными как текст - PullRequest
2 голосов
/ 01 сентября 2009

Я прочитал несколько уроков онлайн и, похоже, что-то упустил. Я пытаюсь отобразить первые 0 в столбцах, установив формат текста.

Любые предложения будут оценены.

    ''' <summary>
    ''' This is required for the grid view to export properly
    ''' </summary>
    ''' <param name="control"></param>
    ''' <remarks></remarks>
    Public Overrides Sub VerifyRenderingInServerForm(ByVal control As System.Web.UI.Control)
    End Sub

    Protected Overrides Sub OnInitComplete(ByVal e As System.EventArgs)

            Dim List As System.Web.UI.WebControls.GridView = CType(Page.FindControl("List"), System.Web.UI.WebControls.GridView)
            AddHandler List.RowDataBound, AddressOf RowDataBound

            List.DataSource = myList
            List.DataBind()

            Response.Clear()
            Response.ContentType = "application/vnd.ms-excel"
            HttpContext.Current.Response.AddHeader("Content-Disposition", "attachment; filename=ExportList.xls")

            Response.Write("<style> .text {mso-number-format:\@; } </style>")

            Using strwriter As New System.IO.StringWriter
                Using htmlwriter As New HtmlTextWriter(strwriter)

                    List.RenderControl(htmlwriter)

                    HttpContext.Current.Response.Write(strwriter.ToString)
                    HttpContext.Current.ApplicationInstance.CompleteRequest()
                End Using
            End Using

    End Sub

    Protected Sub RowDataBound(ByVal sender As Object, ByVal e As System.Web.UI.WebControls.GridViewRowEventArgs)

        If e.Row.RowType = DataControlRowType.DataRow Then

            e.Row.Cells(0).Attributes.Add("class", "text")

            Dim dtview As System.Data.DataRowView
            Dim dt As DateTime
            Dim intCounter As Integer

            dtview = e.Row.DataItem

            For intCounter = 0 To dtview.Row.ItemArray.Length - 1

                If TypeOf dtview.Row.Item(intCounter) Is System.DateTime Then
                    dt = dtview.Row.Item(intCounter)
                    e.Row.Cells(intCounter).Text = dt.ToLongDateString
                End If

            Next
        End If

    End Sub

Ответы [ 2 ]

5 голосов
/ 02 марта 2012

Есть лучший способ достичь того же результата, просто добавьте одну строку, и она будет работать. Вместо создания таблицы стилей и добавления атрибутов для всех тегов <TD> с помощью цикла, примените прямой стиль ко всем тегам TD.

string style = @"<style> TD { mso-number-format:\@; } </style>";
0 голосов
/ 19 ноября 2009

Проверьте это: Как экспортировать GridView в Word Excel PDF и CSV документы

Работает нормально. Самый лучший. Спасибо

...