DataGridView导出数据到XML

using System;
using System.IO;
using System.Collections.Generic;
using System.Text;
using System.Data;
using System.Drawing;
using System.Windows.Forms;

namespace Config
{

    class ExportHelper
    {

        #region " DataGridViewToXml "

        public void DataGridViewToXml(DataGridView dataGridView, String filePath)
        {
            DataGridViewToXml(new DataGridViewExportOptions(dataGridView), filePath);
        }

        public void DataGridViewToXml(DataGridViewExportOptions dataGridViewExportOption, String filePath)
        {
            DataGridViewToXml(new List<DataGridViewExportOptions>(new DataGridViewExportOptions[] { dataGridViewExportOption }), filePath);
        }

        public void DataGridViewToXml(List<DataGridViewExportOptions> dataGridViewExportOptions, String filePath)
        {
            if (dataGridViewExportOptions == null || dataGridViewExportOptions.Count == 0) return;

            DataSet dataSet = new DataSet("Lists");

            int sheetIndex = 1;
            List<String> sheetNames = new List<String>();
            try
            {
                foreach (DataGridViewExportOptions option in dataGridViewExportOptions)
                {
                    #region " 处理在多个 DataGridView 设置为相同的表名称的问题 "
                    if (sheetNames.Contains(option.WorkSheetName))
                    {
                        int i = 1;
                        while (true)
                        {
                            string newSheetName = option.WorkSheetName + i.ToString();
                            if (!sheetNames.Contains(newSheetName))
                            {
                                sheetNames.Add(newSheetName);
                                option.WorkSheetName = newSheetName;
                                break;
                            }
                            i++;
                        }
                    }
                    else
                    {
                        sheetNames.Add(option.WorkSheetName);
                    }
                    DataGridViewFillToDataSet(dataSet, option);
                    sheetIndex++;
                    #endregion
                }
                ExportToXml(dataSet, filePath);
            }
            finally
            {
                dataSet.Dispose();
                GC.Collect();
            }
        }

        // 处理 DataGridView 中的数据以填充到指定的 DataSet 中    
        private void DataGridViewFillToDataSet(DataSet dataSet, DataGridViewExportOptions Option)
        {
            DataTable Table = new DataTable();
            Table.TableName = Option.WorkSheetName;

            if (Option.DataGridView == null) return;

            #region " 填充表头内容 "

            foreach (DataColumnExportOptions option in Option.VisibleColumnOptions)
            {
                if (!option.Visible) continue;
                Table.Columns.Add(new DataColumn(option.ColumnName));
            }

            #endregion

            #region " 填充表格正文内容 "

            foreach (DataGridViewRow dataRow in Option.DataGridView.Rows)
            {
                if (dataRow.IsNewRow) continue;

                DataRow Row = Table.NewRow();
                foreach (DataColumnExportOptions option in Option.VisibleColumnOptions)
                {
                    if (dataRow.Cells[option.ColumnName].Value == null)
                    {
                        Row[option.ColumnName] = "";
                    }
                    else
                    {
                        Row[option.ColumnName] = dataRow.Cells[option.ColumnName].Value.ToString();
                    }
                }
                Table.Rows.Add(Row);
            }

            #endregion
            dataSet.Tables.Add(Table);
        }

        #endregion

        #region " ExportToXml "
        /// <summary>    
        /// 保存 DataSet 数据到 Xml 文件    
        /// </summary>    
        /// <param name="dataSet">DataSet数据对象</param>    
        /// <param name="filePath">Xml 文件地址</param>
        private void ExportToXml(DataSet dataSet, String filePath)
        {
            #region " 判断文件是否存在,存在则删除原有文件 "
            try
            {
                if (File.Exists(filePath)) File.Delete(filePath);
            }
            catch
            {
                return;
            }
            #endregion

            dataSet.WriteXml(filePath);
        }
        #endregion

        #region ImportXML
        public void Xml2DataGridView(DataGridView dataGridView, String filePath)
        {
            System.Data.DataSet dataSet1 = new System.Data.DataSet(); ;
            dataGridView.Rows.Clear();
            dataSet1.ReadXml(filePath, XmlReadMode.Auto);

            DataTable dt = dataSet1.Tables[0];
            dataGridView.Rows.Add(dt.Rows.Count);
            for (int i = 0; i < dt.Rows.Count; i++)
            {
                object[] data = dt.Rows[i].ItemArray;
                for (int j = 0; j < data.Length; j++)
                {
                    dataGridView[j, i].Value = data[j];
                }
            }
        }
        #endregion


    }


    #region " DataColumnExportOptions "
    /// <summary>    
    /// 导出数据字段属性选项类    
    /// </summary>
    class DataColumnExportOptions
    {
        private String _ColumnName;
        private String _Caption;
        private Boolean _Visible;
        /// <summary>    
        /// 字段名称    
        /// </summary>
        public String ColumnName
        {
            get { return _ColumnName; }
            set { _ColumnName = value; }
        }
        /// <summary>    
        /// 字段标题    
        /// </summary>
        public String Caption
        {
            get { return _Caption; }
            set { _Caption = value; }
        }
        /// <summary>    
        /// 是否显示(导出)    
        /// </summary>
        public Boolean Visible
        {
            get { return _Visible; }
            set { _Visible = value; }
        }
        /// <summary>    
        /// 构造函数    
        /// </summary>    
        /// <param name="fColumnName">字段名称</param>
        public DataColumnExportOptions(String columnName)
            : this(columnName, columnName)
        {

        }
        /// <summary>    
        /// 构造函数    
        /// </summary>    
        /// <param name="fColumnName">字段名称</param>    
        /// <param name="fCaption">字段标题</param>
        public DataColumnExportOptions(String columnName, String caption)
            : this(columnName, caption, true)
        {

        }
        /// <summary>    
        /// 构造函数    
        /// </summary>    
        /// <param name="fColumnName">字段名称</param>    
        /// <param name="fCaption">字段标题</param>    
        /// <param name="fVisible">是否显示(导出)</param>
        public DataColumnExportOptions(String columnName, String caption, Boolean visible)
        {
            this._ColumnName = columnName;
            this._Caption = caption;
            this._Visible = visible;
        }
    }
    #endregion

    #region " DataGridViewExportOptions “

    class DataGridViewExportOptions
    {
        private DataGridView _DataGridView;
        private List<DataColumnExportOptions> _ColumnOptions;
        private List<DataColumnExportOptions> _VisibleColumnOptions;
        private String _WorkSheetName;

        /// <summary>    
        /// 要导出到DataGridView对象    
        /// </summary>
        public DataGridView DataGridView
        {
            get { return _DataGridView; }
            set { _DataGridView = value; }
        }
        /// <summary>    
        /// 导出的字段属性列表    
        /// </summary>
        public List<DataColumnExportOptions> ColumnOptions
        {
            get { return _ColumnOptions; }
            set { _ColumnOptions = value; }
        }
        /// <summary>    
        /// 要导出的字段列表(只读)    
        /// </summary>
        public List<DataColumnExportOptions> VisibleColumnOptions
        {
            get { return _VisibleColumnOptions; }
        }
        /// <summary>    
        /// 导出的工作表名称    
        /// </summary>
        public String WorkSheetName
        {
            get { return _WorkSheetName; }
            set { _WorkSheetName = value; }
        }
        /// <summary>    
        /// 构造函数    
        /// </summary>    
        /// <param name="dataGridView">要导出到DataGridView对象</param>
        public DataGridViewExportOptions(DataGridView dataGridView)
            : this(dataGridView, null)
        { }
        /// <summary>    
        /// 构造函数    
        /// </summary>    
        /// <param name="dataGridView">要导出到DataGridView对象</param>    
        /// <param name="columnOptions">导出的字段属性列表</param>
        public DataGridViewExportOptions(DataGridView dataGridView, List<DataColumnExportOptions> columnOptions)
            : this(dataGridView, columnOptions, null) { }
        /// <summary>    
        /// 构造函数    
        /// </summary>    
        /// <param name="dataGridView">要导出到DataGridView对象</param>    
        /// <param name="columnOptions">导出的字段属性列表</param>    
        /// <param name="workSheetName">导出生成的工作表名称</param>
        public DataGridViewExportOptions(DataGridView dataGridView, List<DataColumnExportOptions> columnOptions, String workSheetName)
        {
            if (dataGridView == null) return;

            this._DataGridView = dataGridView;
            if (columnOptions == null)
            {
                this._ColumnOptions = new List<DataColumnExportOptions>();
                foreach (DataGridViewColumn dataColumn in dataGridView.Columns)
                    this._ColumnOptions.Add(new DataColumnExportOptions(dataColumn.Name, dataColumn.HeaderText, dataColumn.Visible));
            }
            else
            {
                this._ColumnOptions = columnOptions;
            }

            if (String.IsNullOrEmpty(workSheetName))
                this._WorkSheetName = dataGridView.Name;
            else
                this._WorkSheetName = workSheetName;

            this._VisibleColumnOptions = new List<DataColumnExportOptions>();
            foreach (DataColumnExportOptions option in this._ColumnOptions)
            {
                if (option.Visible)
                    this._VisibleColumnOptions.Add(option);
            }
        }
    }

    #endregion






}

转载于:https://www.cnblogs.com/WilliamJiang/archive/2012/06/04/2534985.html

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: DataGridView是.NET平台下的一种数据显示控件,支持将数据导出为多种格式,包括Excel、CSV、HTML等。下面我将详细介绍如何使用DataGridView导出数据。 首先,我们需要将DataGridView中的数据保存为DataTable。可以通过以下代码实现: ``` DataTable dt = new DataTable(); foreach (DataGridViewColumn column in dataGridView1.Columns) { dt.Columns.Add(column.HeaderText, column.ValueType); } foreach (DataGridViewRow row in dataGridView1.Rows) { dt.Rows.Add(); for (int i = 0; i < dataGridView1.Columns.Count; i++) { dt.Rows[row.Index][i] = dataGridView1.Rows[row.Index].Cells[i].Value; } } ``` 接下来,可以使用DataTable的方法将数据导出到不同的格式。以导出为Excel为例,可以使用以下代码: ``` SaveFileDialog saveFileDialog = new SaveFileDialog(); saveFileDialog.Filter = "Excel文件|*.xlsx"; saveFileDialog.Title = "导出Excel文件"; saveFileDialog.FileName = "导出数据"; if (saveFileDialog.ShowDialog() == DialogResult.OK) { using (ExcelPackage excelPackage = new ExcelPackage()) { ExcelWorksheet worksheet = excelPackage.Workbook.Worksheets.Add("Sheet1"); int rowIndex = 1; foreach (DataColumn column in dt.Columns) { worksheet.Cells[1, rowIndex].Value = column.ColumnName; rowIndex++; } rowIndex = 2; foreach (DataRow row in dt.Rows) { for (int i = 0; i < dt.Columns.Count; i++) { worksheet.Cells[rowIndex, i + 1].Value = row[i]; } rowIndex++; } FileInfo file = new FileInfo(saveFileDialog.FileName); excelPackage.SaveAs(file); } } ``` 以上就是使用DataGridView导出数据的方法。根据需要可以选择导出为不同的格式,只需要修改保存对话框的过滤器和导出逻辑即可。希望对您有所帮助! ### 回答2: DataGridView是Windows Forms控件中用于显示和编辑表格数据的控件之一。当我们在DataGridView控件中显示了一些数据后,如果需要将这些数据导出到外部文件或者其他系统中,可以使用以下方法实现。 一种常见的方法是使用DataGridView的GetClipboardContent方法。我们可以通过该方法将DataGridView中的数据复制到剪贴板中,然后再将剪贴板的内容粘贴到其他地方。具体步骤如下: 首先,我们需要引入System.Windows.Forms命名空间,以便使用DataGridView控件和相关类。 ``` using System.Windows.Forms; ``` 然后,我们可以通过以下代码导出数据: ``` DataGridView dgv = new DataGridView(); // 假设我们已经有一个DataGridView控件实例 // 假设dgv中已经有数据 dgv.SelectAll(); // 选择DataGridView中的所有数据 DataObject dataObj = dgv.GetClipboardContent(); // 将选择的数据复制到剪贴板中 Clipboard.SetDataObject(dataObj); // 将剪贴板中的数据设置为系统剪贴板中的内容 // 以下是将剪贴板中的内容粘贴到其他地方的步骤 // 这里我们以将数据粘贴到Excel表格中为例 Microsoft.Office.Interop.Excel.Application excel = new Microsoft.Office.Interop.Excel.Application(); excel.Visible = true; Microsoft.Office.Interop.Excel.Workbook workbook = excel.Workbooks.Add(Type.Missing); Microsoft.Office.Interop.Excel.Worksheet worksheet = (Microsoft.Office.Interop.Excel.Worksheet)workbook.ActiveSheet; worksheet.PasteSpecial(Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, true); ``` 上述代码首先创建一个DataGridView实例dgv,并假设该控件中已经有数据。然后通过调用SelectAll方法选择DataGridView中的所有数据,再调用GetClipboardContent方法将数据复制到剪贴板中。接下来,我们创建一个Excel表格并将剪贴板中的内容粘贴到Excel表格中,这里是以将数据粘贴到Excel表格中为例,我们可以根据需要将数据粘贴到其他地方。 当然,除了使用剪贴板,我们还可以使用其他方法实现导出DataGridView数据,例如将数据保存到文件、将数据导出为CSV格式等,具体的方法可以根据需求选择。 ### 回答3: DataGridView 是一个用于显示和编辑数据的控件,而导出数据指的是将 DataGridView 中的数据以某种格式保存到外部文件中。 要实现DataGridView导出数据功能,可以通过以下几个步骤来操作: 1. 首先,需要创建一个saveFileDialog控件,用于选择保存导出数据文件的路径和名称。可以在代码中添加如下语句来创建saveFileDialog控件: ```csharp SaveFileDialog saveFileDialog1 = new SaveFileDialog(); ``` 2. 然后,设置saveFileDialog的默认文件类型和文件名。可以使用Filter属性来指定文件类型,Title属性来设置对话框的标题,InitialDirectory属性来设置对话框打开的初始目录。例如: ```csharp saveFileDialog1.Filter = "CSV文件|*.csv|Excel 文件|*.xls|所有文件|*.*"; saveFileDialog1.Title = "保存导出数据"; saveFileDialog1.InitialDirectory = Environment.GetFolderPath(Environment.SpecialFolder.Desktop); ``` 3. 当用户选择导出数据的文件路径和名称后,可以使用StreamWriter或者Excel对象模型来将数据导出到文件中。 使用StreamWriter的示例代码: ```csharp if (saveFileDialog1.ShowDialog() == DialogResult.OK) { using (StreamWriter sw = new StreamWriter(saveFileDialog1.FileName)) { foreach (DataGridViewRow row in dataGridView1.Rows) { for (int i = 0; i < dataGridView1.Columns.Count; i++) { sw.Write(row.Cells[i].Value.ToString()); sw.Write(","); } sw.WriteLine(); } } } ``` 使用Excel对象模型的示例代码: ```csharp if (saveFileDialog1.ShowDialog() == DialogResult.OK) { Microsoft.Office.Interop.Excel.Application excel = new Microsoft.Office.Interop.Excel.Application(); excel.Visible = false; excel.Workbooks.Add(); Microsoft.Office.Interop.Excel._Worksheet worksheet = excel.ActiveSheet; for (int i = 0; i < dataGridView1.Rows.Count; i++) { for (int j = 0; j < dataGridView1.Columns.Count; j++) { worksheet.Cells[i + 1, j + 1] = dataGridView1.Rows[i].Cells[j].Value.ToString(); } } worksheet.SaveAs(saveFileDialog1.FileName); excel.Quit(); } ``` 通过以上步骤,就可以将 DataGridView 中的数据导出到外部文件中了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值