基于Visual C++2010 与office2010开发办公自动化(24)-使用自动化导出Excel文件

VS2010新特性:

 

  Office Word 2010
  Office Word 2010 增强了 Navigation Pane 特性,用户可在 Navigation Pane 中快速切换至任何一章节的开头(根据标题样式判断),同时也可在输入框中进行即时搜索,包含关键词的章节标题会高亮显示。例如
  Office Word 2010 也增加了在线实时协作功能,用户可以从 Office Word Web App 中启动 Word 2010 进行在线文档的编辑,并可在左下角看到同时编辑的其他用户(包括其他联系方式、IM 等信息,需要 Office Communicator)。而当其他用户修改了某处后,Word 2010 会提醒当前用户进行同步。(注:此功能也存在于部分其他 Office 2010 程序中)
  另外,用户可在 Office Word 2010, Office PowerPoint 2010 以及 Office OneNote 2010 等 Office 2010 程序中直接插入其他正在运行的软件的截图。

Office 2010,是微软推出新一代办公软件,开发代号为Office 14,实际是第12个发行版。该软件共有6个版本,分别是初级版、家庭及学生版、家庭及商业版、标准版、专业版和专业高级版,此外还推出Office 2010免费版本,其中仅包括Word和Excel应用。除了完整版以外,微软还将发布针对Office 2007的升级版Office 2010。Office 2010可支持32位和64位vista及Windows7,仅支持32位WindowsXP,不支持64位XP。

 

Office 2010所包括的全部应用有,Microsoft Access 2010,Microsoft Excel 2010;Microsoft InfoPath Designer 2010;Microsoft InfoPath Filler 2010;Microsoft OneNote 2010;Microsoft Outlook 2010;Microsoft PowerPoint 2010;Microsoft Publisher 2010;Microsoft SharePoint Workspace 2010;Microsoft Word 2010;Office Communicator 2010等。

 

新增功能
  1、截屏工具
  新组件:sharepoint 的加载状态Windows Vista就自带了一个简单的截屏工具,Office2010的Word、PowerPoint等组件里也增加了这个非常有用的功能,在插入标签里可以找到(Screenshot),支持多种截图模式,特别是会自动缓存当前打开窗口的截图,点击一下鼠标就能插入文档中。
  2、背景移除工具(Background Removal)
  可以在Word的图片工具下或者图片属性菜单里找到,在执行简单的抠图操作时就无需动用Photoshop了,还可以添加、去除水印。
  3、保护模式(Protected Mode)
  如果打开从网络上下载的文档,Word 2010会自动处于保护模式下,默认禁止编辑,想要修改就得点一下启用编辑(Enble Editing)。大概是出于版权保护的考虑吧。
  4、新的SmartArt模板
  SmarArt是Office 2007引入的一个很酷的功能,可以轻松制作出精美的业务流程图,而Office 2010在现有类别下增加了大量新模板,还新添了数个新的类别。
  5、作者许可(Author Permissions)
  在线协作是Office 2010的重点努力方向,也符合当今办公趋势。Office 2007里审阅标签下的保护文档现在变成了限制编辑(Restrict Editing),旁边还增加了阻止作者(Block Authors)。
  6、Office按钮文档选项
  Office 2007左上角的圆形按扭及其下的菜单让人印象深刻,到了Office 2010里功能更丰富了,特别是文档操作方面,比如在文档中插入元数据、快速访问权限、保存文档到SharePoint位置等等。
  7、Office按钮打印选项
  打印部分此前只有寥寥三个选项,现在几乎成了一个控制面板,基本可以完成所有打印操作。
  8、Outlook 2010 Jumplist
  Jumplist是Windows 7任务栏的新特性,Outlook 2010也得到了支持,可以迅速访问预约、联系人、任务、日历等功能。

 

  1.全新的安全策略
  Office2010的开发团队给出了一套新的安全战略,通过分析过去的漏洞来了解漏洞是如何被利用的,还要如何做才能防止今后出现类似的情况。Office2010基于五个基本准则建立了新的多层次的安全模型,这是任何一个开发者都应该记住的:
  在执行之前验证所有用户输入
  查找随机缺陷和不典型使用案例
  不要相信第三方库
  不要把安全措施推给用户
  选择降一级的用户体验,而不是全盘否定
  此外,Office2010中还包含一系列的安全性改进,如加强密码的复杂性、查看下载文件的保护模式、对Outlook中电子邮件线程更好的控制等。
  2.Office2010中的编程代码有所改变
  对开发者来讲,为了支持64位,VBA(应用程序的可视化基础)进行了升级,而Office2010对象模型也已经得到了更新。因此,当企业用户自Office2003升级至Office2010的时候,很有可能需要处理旧的、不兼容的程序代码。
  在Office2010中,Outlook可能是受到影响最大的应用程序,对象模型的变化导致了MAPI接口界面以及导航窗口的调整。
  如果企业用户不想要因为无效代码而导致业务中断的话,那么关键就是对代码兼容性进行计划和测试。
  3.强调云共享功能,提升协同作业效率
  新版Office2010的云共享功能包括跟企业SharePoint服务器的整合,让PowerPoint、Word、Excell等Office文件皆可通过SharePoint平台,同时间供多位员工编辑、浏览,提升文件协同作业效率。
  微软还增强了Office与其他微软通信服务之间的联系。如果用户通过Office2010来使用OfficeCommunicationsServer2007R2和OfficeCommunicator2007R2,就可以看到同事的状态并通过电子邮件和即时通信与之举得联系。SharePoint与Office的联系更为紧密,并允许用户对Office文档进行协作。
  4. 新增的Project 2010
  Project2010中的复制粘贴功能也得到了完善,你可以复制粘贴完整格式的内容,任务增至11个,还支持自动换行。在Project2010中可以自动或手动制订任务,自动制订任务功能和之前版本相同,手动制动的任务自动被分配有图钉按钮,默认不会变动。
  新增的TeamPlanner允许用户轻松地查看团队的工作随着时间的变动,快速找出问题,通过拖放等操作解决问题。
  Project2010还新增了TimelineView,用户可以通过该功能总结你的项目然后和其它Office应用分享这一时间线,用户还可以直接将其复制粘贴到其它Office应用比如Outlook或是PowerPoint中。
  5. 模块产品新增功能


  Office Word 2010
  Office Word 2010 增强了 Navigation Pane 特性,用户可在 Navigation Pane 中快速切换至任何一章节的开头(根据标题样式判断),同时也可在输入框中进行即时搜索,包含关键词的章节标题会高亮显示。例如
  Office Word 2010 也增加了在线实时协作功能,用户可以从 Office Word Web App 中启动 Word 2010 进行在线文档的编辑,并可在左下角看到同时编辑的其他用户(包括其他联系方式、IM 等信息,需要 Office Communicator)。而当其他用户修改了某处后,Word 2010 会提醒当前用户进行同步。(注:此功能也存在于部分其他 Office 2010 程序中)
  另外,用户可在 Office Word 2010, Office PowerPoint 2010 以及 Office OneNote 2010 等 Office 2010 程序中直接插入其他正在运行的软件的截图。
  Office Excel 2010
  Office Excel 2010 新增了 Sparklines 特性,可根据用户选择的数据直接在单元格内画出折线图、柱状图等,并配有 Sparklines 设计面板供自定义样式。
  Office PowerPoint 2010
  Office PowerPoint 2010 除了新增更多幻灯片切换特效、图片处理特效之外,还增加了更多视频功能,用户可直接在 PowerPoint 2010 中设定(调节)开始和终止时间剪辑视频,也可将视频嵌入之 PowerPoint 文件中。
  PowerPoint 2010 左侧的幻灯片面板也新增了分区特性,用户可将幻灯片分区归类,也可对整个区内的所有幻灯片进行操作。见下图中的 Default Section 和 LiveSino Section。
  PowerPoint 2010 也增加了类似格式刷的工具 – Animation Painter,可将动画效果应用至其他对象,用法同格式刷。另外就是上次我提到的 Broadcast Slide Show 在线幻灯片播放功能。
  Office Web Applications 2010
   Office Web Applications 2010 包含 Word Web App, Excel Web App, PowerPoint Web App 以及 OneNote Web App,支持简单的编辑及实时协作功能,支持 IE, Firefox, 和 Safari
  Office Mobile 2010
  Office Mobile 2010 包含新版 Word Mobile, Excel Mobile, PowerPoint Mobile, OneNote Mobile 以及支持对话模式的 Outlook Mobile

 

前面我们讲解了如何使用剪贴板导出Excel文件的具体操作流程,这里我介绍另外一种方法:使用自动化导出Excel文件

1.启动VS2010

 

2.创建一个CLR项目如下,在窗体中插入相关若干控件,插入背景,如下图所示:

 

3.添加下列引用

 

4.在Form1.h中插入以下代码,详细见代码分析与注释


view plaincopy to clipboardprint?
#pragma once  
 
 
namespace Yincheng {  
 
    using namespace System;  
    using namespace System::ComponentModel;  
    using namespace System::Collections;  
    using namespace System::Windows::Forms;  
    using namespace System::Data;  
    using namespace System::Drawing;  
 
 
    using namespace System::Data::OleDb;  
    using namespace System::Reflection;  
 
    /// <summary>  
    /// Form1 摘要  
    ///  
    /// 警告: 如果更改此类的名称,则需要更改  
    ///          与此类所依赖的所有 .resx 文件关联的托管资源编译器工具的  
    ///          “资源文件名”属性。否则,  
    ///          设计器将不能与此窗体的关联  
    ///          本地化资源正确交互。  
    /// </summary>  
    public ref class Form1 : public System::Windows::Forms::Form  
    {  
    public:  
        Form1(void)  
        {  
            InitializeComponent();  
            //  
            //TODO: 在此处添加构造函数代码  
            //  
        }  
 
    protected:  
        /// <summary>  
        /// 清理所有正在使用的资源。  
        /// </summary>  
        ~Form1()  
        {  
            if (components)  
            {  
                delete components;  
            }  
        }  
    private: System::Data::DataSet^  dataSet1;  
    protected:   
    private: System::Data::OleDb::OleDbCommand^  oleDbCommand1;  
    private: System::Data::OleDb::OleDbConnection^  oleDbConnection1;  
    private: System::Data::OleDb::OleDbCommand^  oleDbSelectCommand1;  
    private: System::Data::OleDb::OleDbCommand^  oleDbInsertCommand1;  
    private: System::Data::OleDb::OleDbCommand^  oleDbUpdateCommand1;  
    private: System::Data::OleDb::OleDbCommand^  oleDbDeleteCommand1;  
    private: System::Data::OleDb::OleDbDataAdapter^  oleDbDataAdapter1;  
    private: System::Windows::Forms::Label^  label1;  
    private: System::Windows::Forms::TextBox^  textBox1;  
    private: System::Windows::Forms::Button^  button1;  
    private: System::Windows::Forms::Button^  button2;  
    private: System::Windows::Forms::DataGridView^  dataGridView1;  
 
    private:  
        /// <summary>  
        /// 必需的设计器变量。  
        /// </summary>  
        System::ComponentModel::Container ^components; 
 
#pragma region Windows Form Designer generated code  
        /// <summary>  
        /// 设计器支持所需的方法 - 不要  
        /// 使用代码编辑器修改此方法的内容。  
        /// </summary>  
        void InitializeComponent(void)  
        {  
            System::ComponentModel::ComponentResourceManager^  resources = (gcnew System::ComponentModel::ComponentResourceManager(Form1::typeid));  
            this->dataSet1 = (gcnew System::Data::DataSet());  
            this->oleDbCommand1 = (gcnew System::Data::OleDb::OleDbCommand());  
            this->oleDbConnection1 = (gcnew System::Data::OleDb::OleDbConnection());  
            this->oleDbSelectCommand1 = (gcnew System::Data::OleDb::OleDbCommand());  
            this->oleDbInsertCommand1 = (gcnew System::Data::OleDb::OleDbCommand());  
            this->oleDbUpdateCommand1 = (gcnew System::Data::OleDb::OleDbCommand());  
            this->oleDbDeleteCommand1 = (gcnew System::Data::OleDb::OleDbCommand());  
            this->oleDbDataAdapter1 = (gcnew System::Data::OleDb::OleDbDataAdapter());  
            this->label1 = (gcnew System::Windows::Forms::Label());  
            this->textBox1 = (gcnew System::Windows::Forms::TextBox());  
            this->button1 = (gcnew System::Windows::Forms::Button());  
            this->button2 = (gcnew System::Windows::Forms::Button());  
            this->dataGridView1 = (gcnew System::Windows::Forms::DataGridView());  
            (cli::safe_cast<System::ComponentModel::ISupportInitialize^  >(this->dataSet1))->BeginInit();  
            (cli::safe_cast<System::ComponentModel::ISupportInitialize^  >(this->dataGridView1))->BeginInit();  
            this->SuspendLayout();  
            //   
            // dataSet1  
            //   
            this->dataSet1->DataSetName = L"NewDataSet";  
            //   
            // oleDbDataAdapter1  
            //   
            this->oleDbDataAdapter1->DeleteCommand = this->oleDbDeleteCommand1;  
            this->oleDbDataAdapter1->InsertCommand = this->oleDbInsertCommand1;  
            this->oleDbDataAdapter1->SelectCommand = this->oleDbSelectCommand1;  
            this->oleDbDataAdapter1->UpdateCommand = this->oleDbUpdateCommand1;  
            //   
            // label1  
            //   
            this->label1->AutoSize = true;  
            this->label1->ForeColor = System::Drawing::Color::Coral;  
            this->label1->Location = System::Drawing::Point(129, 38);  
            this->label1->Name = L"label1";  
            this->label1->Size = System::Drawing::Size(83, 12);  
            this->label1->TabIndex = 0;  
            this->label1->Text = L"SQL查询语句:";  
            //   
            // textBox1  
            //   
            this->textBox1->Location = System::Drawing::Point(208, 34);  
            this->textBox1->Name = L"textBox1";  
            this->textBox1->Size = System::Drawing::Size(145, 21);  
            this->textBox1->TabIndex = 1;  
            this->textBox1->Text = L"Select * From 客户";  
            //   
            // button1  
            //   
            this->button1->Location = System::Drawing::Point(357, 32);  
            this->button1->Name = L"button1";  
            this->button1->Size = System::Drawing::Size(75, 23);  
            this->button1->TabIndex = 2;  
            this->button1->Text = L"显示数据";  
            this->button1->UseVisualStyleBackColor = true;  
            this->button1->Click += gcnew System::EventHandler(this, &Form1::button1_Click);  
            //   
            // button2  
            //   
            this->button2->Location = System::Drawing::Point(432, 32);  
            this->button2->Name = L"button2";  
            this->button2->Size = System::Drawing::Size(80, 23);  
            this->button2->TabIndex = 3;  
            this->button2->Text = L"导出Excel表";  
            this->button2->UseVisualStyleBackColor = true;  
            this->button2->Click += gcnew System::EventHandler(this, &Form1::button2_Click);  
            //   
            // dataGridView1  
            //   
            this->dataGridView1->Anchor = static_cast<System::Windows::Forms::AnchorStyles>((((System::Windows::Forms::AnchorStyles::Top | System::Windows::Forms::AnchorStyles::Bottom)   
                | System::Windows::Forms::AnchorStyles::Left)   
                | System::Windows::Forms::AnchorStyles::Right));  
            this->dataGridView1->ColumnHeadersHeightSizeMode = System::Windows::Forms::DataGridViewColumnHeadersHeightSizeMode::AutoSize;  
            this->dataGridView1->Location = System::Drawing::Point(35, 58);  
            this->dataGridView1->Name = L"dataGridView1";  
            this->dataGridView1->RowTemplate->Height = 23;  
            this->dataGridView1->Size = System::Drawing::Size(601, 332);  
            this->dataGridView1->TabIndex = 4;  
            //   
            // Form1  
            //   
            this->AutoScaleDimensions = System::Drawing::SizeF(6, 12);  
            this->AutoScaleMode = System::Windows::Forms::AutoScaleMode::Font;  
            this->BackColor = System::Drawing::SystemColors::ActiveCaptionText;  
            this->BackgroundImage = (cli::safe_cast<System::Drawing::Image^  >(resources->GetObject(L"$this.BackgroundImage")));  
            this->ClientSize = System::Drawing::Size(674, 414);  
            this->Controls->Add(this->dataGridView1);  
            this->Controls->Add(this->button2);  
            this->Controls->Add(this->button1);  
            this->Controls->Add(this->textBox1);  
            this->Controls->Add(this->label1);  
            this->Name = L"Form1";  
            this->StartPosition = System::Windows::Forms::FormStartPosition::CenterScreen;  
            this->Text = L"CSDN技术专家尹成-演示使用自动化导出Excel文件";  
            (cli::safe_cast<System::ComponentModel::ISupportInitialize^  >(this->dataSet1))->EndInit();  
            (cli::safe_cast<System::ComponentModel::ISupportInitialize^  >(this->dataGridView1))->EndInit();  
            this->ResumeLayout(false);  
            this->PerformLayout();  
 
        } 
#pragma endregion  
    //显示数据  
    private: System::Void button1_Click(System::Object^  sender, System::EventArgs^  e) {  
         try 
         {  
            this->dataSet1 = gcnew DataSet();  
            if (this->oleDbConnection1->State == ConnectionState::Open)  
            this->oleDbConnection1->Close();   
            this->oleDbConnection1->ConnectionString="Provider=Microsoft.Jet.OLEDB.4.0;Data Source="+Application::StartupPath+"//Yincheng.mdb";  
            this->oleDbConnection1->Open();  
            String^ MySQL = this->textBox1->Text;  
            this->oleDbCommand1->CommandText=MySQL;  
            this->oleDbCommand1->Connection=this->oleDbConnection1;  
            this->oleDbDataAdapter1->SelectCommand=this->oleDbCommand1;  
            this->oleDbDataAdapter1->Fill(this->dataSet1);  
            this->dataGridView1->DataSource =this->dataSet1->Tables[0];  
         }  
         catch (Exception^ MyEx)  
         {  
             MessageBox::Show(MyEx->Message, "信息提示", MessageBoxButtons::OK, MessageBoxIcon::Information);  
         }  
    }  
    //导出Excel表  
private: System::Void button2_Click(System::Object^  sender, System::EventArgs^  e) {  
             Excel::ApplicationClass^ MyExcel;  
             Excel::Workbooks^ MyWorkBooks;  
             Excel::Workbook^ MyWorkBook;  
             Excel::Worksheet^ MyWorkSheet;  
             Excel::Range^ MyRange;  
             array<System::Object^,2>^ MyData=gcnew array<System::Object^,2>(5000,30);  
             OleDbDataReader^ MyReader;  
             DataColumn^ MyColumn;  
             int Count,i,j;  
             try 
             {  
                 MyExcel = gcnew Excel::ApplicationClass();  
                 MyExcel->Visible = true;        
                 MyWorkBooks=MyExcel->Workbooks;  
                 MyWorkBook=MyWorkBooks->Add(Missing::Value);  
                 MyWorkSheet=(Excel::Worksheet^)MyWorkBook->Worksheets[1];  
                 switch(this->dataSet1->Tables[0]->Columns->Count + 64)  
                 {  
                    case 64:  
                         MyRange=MyWorkSheet->Range["A1","A1"];  
                        break;  
                    case 65:  
                        MyRange=MyWorkSheet->Range["A1","B1"];  
                        break;  
                    case 66:  
                        MyRange=MyWorkSheet->Range["A1","C1"];  
                        break;  
                    case 67:  
                        MyRange=MyWorkSheet->Range["A1","D1"];  
                        break;  
                    case 68:  
                        MyRange=MyWorkSheet->Range["A1","E1"];  
                        break;  
                    case 69:  
                        MyRange=MyWorkSheet->Range["A1","F1"];  
                        break;  
                    case 70:  
                        MyRange=MyWorkSheet->Range["A1","G1"];  
                        break;  
                    case 71:  
                        MyRange=MyWorkSheet->Range["A1","H1"];  
                        break;  
                    case 72:  
                        MyRange=MyWorkSheet->Range["A1","I1"];  
                        break;  
                    case 73:  
                        MyRange=MyWorkSheet->Range["A1","J1"];  
                        break;  
                    case 74:  
                        MyRange=MyWorkSheet->Range["A1","K1"];  
                        break;  
                    case 75:  
                        MyRange=MyWorkSheet->Range["A1","L1"];  
                        break;  
                    case 76:  
                        MyRange=MyWorkSheet->Range["A1","M1"];  
                        break;  
                    case 77:  
                        MyRange=MyWorkSheet->Range["A1","N1"];  
                        break;  
                    case 78:  
                        MyRange=MyWorkSheet->Range["A1","O1"];  
                        break;  
                    case 79:  
                        MyRange=MyWorkSheet->Range["A1","P1"];  
                        break;  
                    case 80:  
                        MyRange=MyWorkSheet->Range["A1","Q1"];  
                        break;  
                    case 81:  
                        MyRange=MyWorkSheet->Range["A1","R1"];  
                        break;  
                    case 82:  
                        MyRange=MyWorkSheet->Range["A1","S1"];  
                        break;  
                    case 83:  
                        MyRange=MyWorkSheet->Range["A1","T1"];  
                        break;  
                    case 84:  
                        MyRange=MyWorkSheet->Range["A1","U1"];  
                        break;  
                    case 85:  
                        MyRange=MyWorkSheet->Range["A1","V1"];  
                        break;  
                    case 86:  
                        MyRange=MyWorkSheet->Range["A1","W1"];  
                        break;  
                    case 87:  
                        MyRange=MyWorkSheet->Range["A1","X1"];  
                        break;  
                    case 88:  
                        MyRange=MyWorkSheet->Range["A1","Y1"];  
                        break;  
                    case 89:  
                        MyRange=MyWorkSheet->Range["A1","Z1"];  
                        break;  
                 }                     
                 MyReader=oleDbCommand1->ExecuteReader();  
                 Count=0;  
                 for each(DataColumn^ MyNewColumn in this->dataSet1->Tables[0]->Columns)  
                 {  
                    MyData[0,Count]=MyNewColumn->ColumnName;  
                    Count=Count+1;  
                 }  
                //设标题为黑体字     
                 MyWorkSheet->Range[MyWorkSheet->Cells[1,1],MyWorkSheet->Cells[1,Count]]->Font->Name="黑体";  
                //标题字体加粗    
                MyWorkSheet->Range[MyWorkSheet->Cells[1,1],MyWorkSheet->Cells[1,Count]]->Font->Bold=true;  
                //设表格边框样式     
                MyWorkSheet->Range[MyWorkSheet->Cells[1,1],MyWorkSheet->Cells[1,Count]]->Borders->LineStyle=1;  
                j=1;  
                while(MyReader->Read())  
                {  
                    for(i=0;i< MyReader->FieldCount;i++)  
                    {  
                        MyData[j,i]=MyReader[i]->ToString();  
                    }  
                    j++;  
                }  
                MyReader->Close();  
                MyRange=MyRange->Resize[this->dataSet1->Tables[0]->Rows->Count,this->dataSet1->Tables[0]->Columns->Count];  
                MyRange->Value2=MyData;  
                MyRange->EntireColumn->AutoFit();  
            }  
            catch (Exception^ MyEx)  
            {  
                MessageBox::Show(MyEx->Message, "信息提示", MessageBoxButtons::OK, MessageBoxIcon::Information);  
            }  
         }  
};  

#pragma once


namespace Yincheng {

 using namespace System;
 using namespace System::ComponentModel;
 using namespace System::Collections;
 using namespace System::Windows::Forms;
 using namespace System::Data;
 using namespace System::Drawing;


 using namespace System::Data::OleDb;
 using namespace System::Reflection;

 /// <summary>
 /// Form1 摘要
 ///
 /// 警告: 如果更改此类的名称,则需要更改
 ///          与此类所依赖的所有 .resx 文件关联的托管资源编译器工具的
 ///          “资源文件名”属性。否则,
 ///          设计器将不能与此窗体的关联
 ///          本地化资源正确交互。
 /// </summary>
 public ref class Form1 : public System::Windows::Forms::Form
 {
 public:
  Form1(void)
  {
   InitializeComponent();
   //
   //TODO: 在此处添加构造函数代码
   //
  }

 protected:
  /// <summary>
  /// 清理所有正在使用的资源。
  /// </summary>
  ~Form1()
  {
   if (components)
   {
    delete components;
   }
  }
 private: System::Data::DataSet^  dataSet1;
 protected:
 private: System::Data::OleDb::OleDbCommand^  oleDbCommand1;
 private: System::Data::OleDb::OleDbConnection^  oleDbConnection1;
 private: System::Data::OleDb::OleDbCommand^  oleDbSelectCommand1;
 private: System::Data::OleDb::OleDbCommand^  oleDbInsertCommand1;
 private: System::Data::OleDb::OleDbCommand^  oleDbUpdateCommand1;
 private: System::Data::OleDb::OleDbCommand^  oleDbDeleteCommand1;
 private: System::Data::OleDb::OleDbDataAdapter^  oleDbDataAdapter1;
 private: System::Windows::Forms::Label^  label1;
 private: System::Windows::Forms::TextBox^  textBox1;
 private: System::Windows::Forms::Button^  button1;
 private: System::Windows::Forms::Button^  button2;
 private: System::Windows::Forms::DataGridView^  dataGridView1;

 private:
  /// <summary>
  /// 必需的设计器变量。
  /// </summary>
  System::ComponentModel::Container ^components;

#pragma region Windows Form Designer generated code
  /// <summary>
  /// 设计器支持所需的方法 - 不要
  /// 使用代码编辑器修改此方法的内容。
  /// </summary>
  void InitializeComponent(void)
  {
   System::ComponentModel::ComponentResourceManager^  resources = (gcnew System::ComponentModel::ComponentResourceManager(Form1::typeid));
   this->dataSet1 = (gcnew System::Data::DataSet());
   this->oleDbCommand1 = (gcnew System::Data::OleDb::OleDbCommand());
   this->oleDbConnection1 = (gcnew System::Data::OleDb::OleDbConnection());
   this->oleDbSelectCommand1 = (gcnew System::Data::OleDb::OleDbCommand());
   this->oleDbInsertCommand1 = (gcnew System::Data::OleDb::OleDbCommand());
   this->oleDbUpdateCommand1 = (gcnew System::Data::OleDb::OleDbCommand());
   this->oleDbDeleteCommand1 = (gcnew System::Data::OleDb::OleDbCommand());
   this->oleDbDataAdapter1 = (gcnew System::Data::OleDb::OleDbDataAdapter());
   this->label1 = (gcnew System::Windows::Forms::Label());
   this->textBox1 = (gcnew System::Windows::Forms::TextBox());
   this->button1 = (gcnew System::Windows::Forms::Button());
   this->button2 = (gcnew System::Windows::Forms::Button());
   this->dataGridView1 = (gcnew System::Windows::Forms::DataGridView());
   (cli::safe_cast<System::ComponentModel::ISupportInitialize^  >(this->dataSet1))->BeginInit();
   (cli::safe_cast<System::ComponentModel::ISupportInitialize^  >(this->dataGridView1))->BeginInit();
   this->SuspendLayout();
   //
   // dataSet1
   //
   this->dataSet1->DataSetName = L"NewDataSet";
   //
   // oleDbDataAdapter1
   //
   this->oleDbDataAdapter1->DeleteCommand = this->oleDbDeleteCommand1;
   this->oleDbDataAdapter1->InsertCommand = this->oleDbInsertCommand1;
   this->oleDbDataAdapter1->SelectCommand = this->oleDbSelectCommand1;
   this->oleDbDataAdapter1->UpdateCommand = this->oleDbUpdateCommand1;
   //
   // label1
   //
   this->label1->AutoSize = true;
   this->label1->ForeColor = System::Drawing::Color::Coral;
   this->label1->Location = System::Drawing::Point(129, 38);
   this->label1->Name = L"label1";
   this->label1->Size = System::Drawing::Size(83, 12);
   this->label1->TabIndex = 0;
   this->label1->Text = L"SQL查询语句:";
   //
   // textBox1
   //
   this->textBox1->Location = System::Drawing::Point(208, 34);
   this->textBox1->Name = L"textBox1";
   this->textBox1->Size = System::Drawing::Size(145, 21);
   this->textBox1->TabIndex = 1;
   this->textBox1->Text = L"Select * From 客户";
   //
   // button1
   //
   this->button1->Location = System::Drawing::Point(357, 32);
   this->button1->Name = L"button1";
   this->button1->Size = System::Drawing::Size(75, 23);
   this->button1->TabIndex = 2;
   this->button1->Text = L"显示数据";
   this->button1->UseVisualStyleBackColor = true;
   this->button1->Click += gcnew System::EventHandler(this, &Form1::button1_Click);
   //
   // button2
   //
   this->button2->Location = System::Drawing::Point(432, 32);
   this->button2->Name = L"button2";
   this->button2->Size = System::Drawing::Size(80, 23);
   this->button2->TabIndex = 3;
   this->button2->Text = L"导出Excel表";
   this->button2->UseVisualStyleBackColor = true;
   this->button2->Click += gcnew System::EventHandler(this, &Form1::button2_Click);
   //
   // dataGridView1
   //
   this->dataGridView1->Anchor = static_cast<System::Windows::Forms::AnchorStyles>((((System::Windows::Forms::AnchorStyles::Top | System::Windows::Forms::AnchorStyles::Bottom)
    | System::Windows::Forms::AnchorStyles::Left)
    | System::Windows::Forms::AnchorStyles::Right));
   this->dataGridView1->ColumnHeadersHeightSizeMode = System::Windows::Forms::DataGridViewColumnHeadersHeightSizeMode::AutoSize;
   this->dataGridView1->Location = System::Drawing::Point(35, 58);
   this->dataGridView1->Name = L"dataGridView1";
   this->dataGridView1->RowTemplate->Height = 23;
   this->dataGridView1->Size = System::Drawing::Size(601, 332);
   this->dataGridView1->TabIndex = 4;
   //
   // Form1
   //
   this->AutoScaleDimensions = System::Drawing::SizeF(6, 12);
   this->AutoScaleMode = System::Windows::Forms::AutoScaleMode::Font;
   this->BackColor = System::Drawing::SystemColors::ActiveCaptionText;
   this->BackgroundImage = (cli::safe_cast<System::Drawing::Image^  >(resources->GetObject(L"$this.BackgroundImage")));
   this->ClientSize = System::Drawing::Size(674, 414);
   this->Controls->Add(this->dataGridView1);
   this->Controls->Add(this->button2);
   this->Controls->Add(this->button1);
   this->Controls->Add(this->textBox1);
   this->Controls->Add(this->label1);
   this->Name = L"Form1";
   this->StartPosition = System::Windows::Forms::FormStartPosition::CenterScreen;
   this->Text = L"CSDN技术专家尹成-演示使用自动化导出Excel文件";
   (cli::safe_cast<System::ComponentModel::ISupportInitialize^  >(this->dataSet1))->EndInit();
   (cli::safe_cast<System::ComponentModel::ISupportInitialize^  >(this->dataGridView1))->EndInit();
   this->ResumeLayout(false);
   this->PerformLayout();

  }
#pragma endregion
 //显示数据
 private: System::Void button1_Click(System::Object^  sender, System::EventArgs^  e) {
      try
   {
   this->dataSet1 = gcnew DataSet();
   if (this->oleDbConnection1->State == ConnectionState::Open)
            this->oleDbConnection1->Close();
   this->oleDbConnection1->ConnectionString="Provider=Microsoft.Jet.OLEDB.4.0;Data Source="+Application::StartupPath+"//Yincheng.mdb";
   this->oleDbConnection1->Open();
   String^ MySQL = this->textBox1->Text;
   this->oleDbCommand1->CommandText=MySQL;
   this->oleDbCommand1->Connection=this->oleDbConnection1;
   this->oleDbDataAdapter1->SelectCommand=this->oleDbCommand1;
   this->oleDbDataAdapter1->Fill(this->dataSet1);
   this->dataGridView1->DataSource =this->dataSet1->Tables[0];
      }
   catch (Exception^ MyEx)
   {
    MessageBox::Show(MyEx->Message, "信息提示", MessageBoxButtons::OK, MessageBoxIcon::Information);
   }
 }
    //导出Excel表
private: System::Void button2_Click(System::Object^  sender, System::EventArgs^  e) {
    Excel::ApplicationClass^ MyExcel;
    Excel::Workbooks^ MyWorkBooks;
    Excel::Workbook^ MyWorkBook;
    Excel::Worksheet^ MyWorkSheet;
    Excel::Range^ MyRange;
    array<System::Object^,2>^ MyData=gcnew array<System::Object^,2>(5000,30);
    OleDbDataReader^ MyReader;
    DataColumn^ MyColumn;
    int Count,i,j;
    try
    {
     MyExcel = gcnew Excel::ApplicationClass();
     MyExcel->Visible = true;     
     MyWorkBooks=MyExcel->Workbooks;
     MyWorkBook=MyWorkBooks->Add(Missing::Value);
     MyWorkSheet=(Excel::Worksheet^)MyWorkBook->Worksheets[1];
     switch(this->dataSet1->Tables[0]->Columns->Count + 64)
     {
     case 64:
       MyRange=MyWorkSheet->Range["A1","A1"];
      break;
     case 65:
      MyRange=MyWorkSheet->Range["A1","B1"];
      break;
     case 66:
      MyRange=MyWorkSheet->Range["A1","C1"];
      break;
     case 67:
      MyRange=MyWorkSheet->Range["A1","D1"];
      break;
     case 68:
      MyRange=MyWorkSheet->Range["A1","E1"];
      break;
     case 69:
      MyRange=MyWorkSheet->Range["A1","F1"];
      break;
     case 70:
      MyRange=MyWorkSheet->Range["A1","G1"];
      break;
     case 71:
      MyRange=MyWorkSheet->Range["A1","H1"];
      break;
     case 72:
      MyRange=MyWorkSheet->Range["A1","I1"];
      break;
     case 73:
      MyRange=MyWorkSheet->Range["A1","J1"];
      break;
     case 74:
      MyRange=MyWorkSheet->Range["A1","K1"];
      break;
     case 75:
      MyRange=MyWorkSheet->Range["A1","L1"];
      break;
     case 76:
      MyRange=MyWorkSheet->Range["A1","M1"];
      break;
     case 77:
      MyRange=MyWorkSheet->Range["A1","N1"];
      break;
     case 78:
      MyRange=MyWorkSheet->Range["A1","O1"];
      break;
     case 79:
      MyRange=MyWorkSheet->Range["A1","P1"];
      break;
     case 80:
      MyRange=MyWorkSheet->Range["A1","Q1"];
      break;
     case 81:
      MyRange=MyWorkSheet->Range["A1","R1"];
      break;
     case 82:
      MyRange=MyWorkSheet->Range["A1","S1"];
      break;
     case 83:
      MyRange=MyWorkSheet->Range["A1","T1"];
      break;
     case 84:
      MyRange=MyWorkSheet->Range["A1","U1"];
      break;
     case 85:
      MyRange=MyWorkSheet->Range["A1","V1"];
      break;
     case 86:
      MyRange=MyWorkSheet->Range["A1","W1"];
      break;
     case 87:
      MyRange=MyWorkSheet->Range["A1","X1"];
      break;
     case 88:
      MyRange=MyWorkSheet->Range["A1","Y1"];
      break;
     case 89:
      MyRange=MyWorkSheet->Range["A1","Z1"];
      break;
     }     
        MyReader=oleDbCommand1->ExecuteReader();
        Count=0;
     for each(DataColumn^ MyNewColumn in this->dataSet1->Tables[0]->Columns)
     {
     MyData[0,Count]=MyNewColumn->ColumnName;
     Count=Count+1;
     }
    //设标题为黑体字  
     MyWorkSheet->Range[MyWorkSheet->Cells[1,1],MyWorkSheet->Cells[1,Count]]->Font->Name="黑体";
    //标题字体加粗 
    MyWorkSheet->Range[MyWorkSheet->Cells[1,1],MyWorkSheet->Cells[1,Count]]->Font->Bold=true;
    //设表格边框样式  
    MyWorkSheet->Range[MyWorkSheet->Cells[1,1],MyWorkSheet->Cells[1,Count]]->Borders->LineStyle=1;
    j=1;
    while(MyReader->Read())
    {
     for(i=0;i< MyReader->FieldCount;i++)
     {
      MyData[j,i]=MyReader[i]->ToString();
     }
     j++;
    }
    MyReader->Close();
    MyRange=MyRange->Resize[this->dataSet1->Tables[0]->Rows->Count,this->dataSet1->Tables[0]->Columns->Count];
    MyRange->Value2=MyData;
    MyRange->EntireColumn->AutoFit();
   }
   catch (Exception^ MyEx)
   {
    MessageBox::Show(MyEx->Message, "信息提示", MessageBoxButtons::OK, MessageBoxIcon::Information);
   }
   }
};
}

5.启动调试运行如下:

 

点击”导出Excel表“按钮启动Excel,显示如下,其中自动插入了一个程序中的表格及数据:

 

成功的演示了使用自动化导出Excel文件的方法,希望读者和前面的用剪贴板导出Excel文件的方法加以区别,实际应用还需读者自行研究揣摩,以实现更为复杂高效的功能。

 

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/yincheng01/archive/2010/06/14/5670906.aspx

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值