博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
asp.net(c#) 将dbf转换为xls或wps,并将数据的列名改成中文;并判断本机是否安装office2003,2007和wps2007,2010...
阅读量:6608 次
发布时间:2019-06-24

本文共 3824 字,大约阅读时间需要 12 分钟。

using Microsoft.Office.Interop.Excel;//转换为excel时,需要引用此命名空间

using ET;//转换为wps时,需要引用此命名空间

using KSO;//转换为wps时,需要引用此命名空间
当转换为excel时,需要引入Microsoft.Office.Interop.Excel.dll;当转换为wps时,需要引入Interop.ET.dll,Interop.KSO.dll;

 

#region 查询注册表,判断本机是否安装office2003,2007和wps

        public int ExistsRegedit()
        {
            int ifused = 0;
            RegistryKey rk = Registry.LocalMachine;
            RegistryKey akey = rk.OpenSubKey(@"SOFTWARE\Microsoft\Office\11.0\Excel\InstallRoot\");//查询2003

    RegistryKey akey07 = rk.OpenSubKey(@"SOFTWARE\Microsoft\Office\12.0\Excel\InstallRoot\");//查询2007

            RegistryKey akeytwo = rk.OpenSubKey(@"SOFTWARE\Kingsoft\Office\6.0\common\");//查询wps
            //检查本机是否安装Office2003
            if (akey != null)
            {
                string file03 = akey.GetValue("Path").ToString();
                if (File.Exists(file03 + "Excel.exe"))
                {
                    ifused += 1;
                }
            }

     //检查本机是否安装Office2007

            if (akey07 != null)

            {
                string file07 = akey.GetValue("Path").ToString();
                if (File.Exists(file07 + "Excel.exe"))
                {
                    ifused += 2;
                }
            }
            //检查本机是否安装wps
            if (akeytwo != null)
            {
                string filewps = akeytwo.GetValue("InstallRoot").ToString();
                if (File.Exists(filewps + @"\office6\et.exe"))
                {
                    ifused += 4;
                }
            }
            return ifused;
        }
        #endregion

 

 

#region 将DBF文件放入DataSet

        private DataSet DbfToDs(string my_TablePath, string my_TableName)
        {
            //数据库连接定义
            OleDbConnection my_conn; //数据连接
            OleDbDataAdapter my_Adapter;//数据适配器
            DataSet my_Ds = null;
            数据库连接
            try
            {
                string path = my_TablePath.Substring(0, my_TablePath.LastIndexOf("\\")) + "\\";
                string connString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + path + ";Extended Properties=dBASE IV;Persist Security Info=False;";
                string my_StrSelect = "SELECT * FROM " + my_TableName;
                my_conn = new OleDbConnection(connString);
                my_Adapter = new OleDbDataAdapter(my_StrSelect, my_conn);
                my_Ds = new DataSet();

                //填充数据集

                my_Adapter.Fill(my_Ds, my_TableName);
            }
            catch (Exception ex)
            {
                MessageBox.Show("选择文件格式不正确,请选择.dbf文件!", "错误", MessageBoxButtons.OK, MessageBoxIcon.Error);
            }

            return my_Ds;

        }
        #endregions

 

#region 把数据文件导入到.xls文件

        public void ExportToExcel(DataSet ds)
        {
            if (ds.Tables.Count != 0)
            {
                //创建excel文件
                Microsoft.Office.Interop.Excel.Application myExcel = new Microsoft.Office.Interop.Excel.ApplicationClass();

                //打开已有的文件

                Microsoft.Office.Interop.Excel.Workbook xBook = myExcel.Workbooks._Open(txtPath.Text , Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value);
                //指定要操作的sheet
                Microsoft.Office.Interop.Excel.Worksheet xSheet = (Microsoft.Office.Interop.Excel.Worksheet)xBook.Sheets[1];

                #region 改成中文列名

                xSheet.Cells[1, 1] = "程序员";

                 .

      .

      .

                //改成中文列名时,可将中文列名放入string[]中,然后循环此数组,将第一行改成相应的中文列名             
                #endregion

                xBook.SaveAs(txtPath.Text, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Microsoft.Office.Interop.Excel.XlSaveAsAccessMode.xlNoChange, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value);

                myExcel.Visible = true;

            }

            else
            {
                System.Windows.Forms.MessageBox.Show("No Data");
            }
        }
        #endregion

 

#region 把数据文件导出为wps

        public void ExportToWps(DataSet ds)
        {
            if (ds.Tables.Count > 0)
            {
                eTApp = new ET.Application();
                eTApp.Visible = false;
                eTWorkBook = eTApp.Workbooks.Open(txtPath.Text, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value);

                eTWorkSheet = (ET.Worksheet)eTWorkBook.Worksheets[1];

                #region 改成中文列名

                eTWorkBook.ActiveSheet.Cells.set_Item(1, 1, "程序员")

                #endregion

                eTWorkBook.SaveAs(txtPath.Text, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, ETSaveAsAccessMode.etNoChange, Missing.Value, Missing.Value, Missing.Value, Missing.Value);

                eTApp.Visible = true;

            }

        }

        #endregion

当转换成xls或者wps时,一般都是循环dataset然后将数据写入每一个单元格,但是当数据量大时转换速度会很慢;所以将数据放入dataset后,可以使用file.copy(文件1,文件2);这样速度会快很多;

转载地址:http://zqiso.baihongyu.com/

你可能感兴趣的文章
Django-form表单
查看>>
Ubuntu 16.04安装Shell管理工具PAC Manager
查看>>
数据库连接字符编码问题
查看>>
jquery-12 jquery的ajax如何使用
查看>>
android Unable to inflate view tag without class attribute
查看>>
FFmpeg 结构体学习(一): AVFormatContext 分析
查看>>
WPF实现双击事件MouseDoubleClick
查看>>
C# 多线程调用静态方法或者静态实例中的同一个方法-方法内部的变量是线程安全的...
查看>>
jmeter 基础功能详解
查看>>
Directx11教程(16) D3D11管线(5)
查看>>
How to determine which patches have been applied
查看>>
Delphi工具之Image Editor
查看>>
ORA-02266: 表中的唯一/主键被启用的外键引用
查看>>
replace与replaceAll的区别
查看>>
Rabbitmq的调度策略
查看>>
Altium Designer部分快捷键和使用技巧
查看>>
Linux 版本 一览
查看>>
ORM
查看>>
【IAR警告】Warning[Pa082]: undefined behavior: the order of volatile accesses is undefined
查看>>
获得表单文件的正文的二进制(环境vbs)
查看>>