如何通过电子邮件发送Gridview

本文关键字:Gridview 电子邮件 何通过 | 更新日期: 2023-09-27 18:10:42

我已经用c#创建了GridView。净(桌面应用程序)。现在我想把这个Gridview通过邮件发送给用户。

请告诉我如何才能实现这一点(通过导出网格到HTML或其他任何东西??)。

我试过下面的HTML,但得到很多格式问题。

dataGridView1.Rows[i].Cells[1].Value = data1.ToString();
dataGridView1.Rows[i].Cells[3].Value = data2.ToString();
mailBody.AppendFormat("<td>{0}</td>",data1.ToString() );
mailBody.AppendFormat("<td>{0}</td>", data2.ToString()); 

如何通过电子邮件发送Gridview

是这样做的…我有Gridview,它是在没有数据源的情况下以编程方式生成的,因此面临问题…

下面的技巧成功了:):)

  DataTable dt = new DataTable();
        foreach (DataGridViewColumn col in dataGridView1.Columns)
        {
            dt.Columns.Add(col.HeaderText);
        }
        foreach (DataGridViewRow row in dataGridView1.Rows)
        {
            DataRow dRow = dt.NewRow();
            foreach (DataGridViewCell cell in row.Cells)
            {
                dRow[cell.ColumnIndex] = cell.Value;
            }
            dt.Rows.Add(dRow);
        }
      //  StringBuilder myBuilder = new StringBuilder();
        myBuilder.Append("<table border='1px' cellpadding='5' cellspacing='0' ");
        myBuilder.Append("style='border: solid 1px Silver; font-size: x-small;'>");
        myBuilder.Append("<tr align='left' valign='top'>");
        foreach (DataColumn myColumn in dt.Columns)
        {
            myBuilder.Append("<td align='left' valign='top'>");
            myBuilder.Append(myColumn.ColumnName);
            myBuilder.Append("</td>");
        }
        myBuilder.Append("</tr>");
        foreach (DataRow myRow in dt.Rows)
        {
            myBuilder.Append("<tr align='left' valign='top'>");
            foreach (DataColumn myColumn in dt.Columns)
            {
                myBuilder.Append("<td align='left' valign='top'>");
                myBuilder.Append(myRow[myColumn.ColumnName].ToString());
                myBuilder.Append("</td>");
            }
            myBuilder.Append("</tr>");
        }
        myBuilder.Append("</table>");
    }