Как пропустить какой-то столбец при экспорте Grid View в Excel? - PullRequest
5 голосов
/ 28 ноября 2011

У меня есть вид сетки.Который содержит несколько столбцов.Предположим, у него есть 10 столбцов, из них только 8 столбцов имеют заголовок, в то время как заголовок 2 столбцов пуст. Теперь я экспортирую это представление сетки в Excel, который содержит все 10 столбцов с 2 столбцами без имени. Как я могу исключить эти 2 пустых столбца заголовка при экспорте GridView в Excel .Я использую следующий код для того же:

        protected void btnExportToExcel_Click(object sender, EventArgs e)
        {
            Export("Customers.xls", this.gdvMessages);
        }

        private void Export(string fileName, GridView gv)
        {
            HttpContext.Current.Response.Clear();
            HttpContext.Current.Response.AddHeader(
            "content-disposition", string.Format("attachment; filename={0}", fileName));
            HttpContext.Current.Response.ContentType = "application/ms-excel";

            using (StringWriter sw = new StringWriter())
            {
                using (HtmlTextWriter htw = new HtmlTextWriter(sw))
                {
                    //  Create a form to contain the grid
                    Table table = new Table();

                    //  add the header row to the table
                    if (gv.HeaderRow != null)
                    {
                        PrepareControlForExport(gv.HeaderRow);
                        table.Rows.Add(gv.HeaderRow);
                    }

                    //  add each of the data rows to the table
                    foreach (GridViewRow row in gv.Rows)
                    {
                        PrepareControlForExport(row);
                        table.Rows.Add(row);
                    }

                    //  add the footer row to the table
                    if (gv.FooterRow != null)
                    {
                        PrepareControlForExport(gv.FooterRow);
                        table.Rows.Add(gv.FooterRow);
                    }

                    //  render the table into the htmlwriter
                    table.RenderControl(htw);

                    //  render the htmlwriter into the response
                    HttpContext.Current.Response.Write(sw.ToString());
                    HttpContext.Current.Response.End();
                }
            }
        }

Ответы [ 2 ]

3 голосов
/ 28 ноября 2011

Вы можете просто не включать эти два столбца в таблицу HTML, если они вам не нужны .... или вы можете переписать таблицу, когда пользователь нажмет кнопку "Экспорт в Excel" и не будет включать столбцы , Вы также можете иметь таблицу плюс другую таблицу со скрытыми столбцами и получать данные из нее, когда пользователь нажимает кнопку «Экспорт в Excel». Кроме того, вы вообще не сможете отобразить данные, и когда пользователь загрузит страницу или нажмет кнопку, загрузите данные без столбцов. Удачи!

EDITED: для этого эксклюзивного сценария вы можете отредактировать код следующим образом:

 //  add the header row to the table
            if (gv.HeaderRow != null)
            {
                TableRow tr = new TableRow();

                foreach (DataControlFieldHeaderCell c in gv.HeaderRow.Cells)
                {
                    if (c.Text != " ") {
                        tr.Cells.Add(new TableCell() { Text = c.Text});
                    }
                }

                PrepareControlForExport(tr);
                table.Rows.Add(tr);
            }

То, что делает эта часть кода, состоит в том, чтобы проходить через каждую ячейку в строке заголовка, и если она пуста, не включайте ее. Затем добавьте его в таблицу HTML. Это может быть изменено, если требуется, чтобы остальная часть таблицы добавила область ячеек, к которой принадлежат эти столбцы. Если это не то, что вам нужно, возможно, пара скриншотов с вашим реальным Gridview и желаемый результат будет идеальным.

Удачи!

2 голосов
/ 21 июня 2013

Вместо этого вы можете скрыть эти столбцы при экспорте в excel, используя приведенный ниже код

this.myGridview.Columns [0] .Visible = false;

, где '0' - это индексстолбец, который мы хотим скрыть.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...