如果你还不太清楚Dspframer.ocx怎么放到窗体上就看上一篇文章,里面详细介绍了是如何放到窗体上的。

链接:http://www.cnblogs.com/pingming/p/4182045.html

第一步 创建新窗体

创建一个新窗体,放置一个panel容器控件,我们就是要将dsoframer.ocx放到panel里面。

第二步 下面是所有调用的方法,有步骤的。

public partial class ExcelForm : DevExpress.XtraEditors.XtraForm
{
private AxDSOFramer.AxFramerControl m_axFramerControl = new AxDSOFramer.AxFramerControl();
public ExcelForm()
{
InitializeComponent(); } #region Excel 的加载 //总的加载Excel方法
private void Init(string _ExcelFilePath)
{
try
{
RegControl(); if (!File.Exists(_ExcelFilePath))
{
XtraMessageBox.Show("文件不存在或未标识的文件格式!", "提示信息");
return;
//throw new ApplicationException("文件不存在或未标识的文件格式!");
} AddAxFramerControl();//加载填充控件

m_axFramerControl.Titlebar = false;//是否显示excel标题栏
                  m_axFramerControl.Menubar = false;//是否显示excel的菜单栏
                  m_axFramerControl.Toolbars = false;//是否显示excel的工具栏

                InitOfficeControl(_ExcelFilePath);
}
catch (Exception ex)
{
throw ex;
} } //第二步:向panel填充AxFramerControl控件
private void AddAxFramerControl()
{
try
{
this.panelExcel.Controls.Add(m_axFramerControl);
m_axFramerControl.Dock = DockStyle.Fill;
}
catch (Exception ex)
{
XtraMessageBox.Show(ex.Message);
throw;
} } //第一步:注册AxFramerControl
public bool RegControl()
{
try
{
Assembly thisExe = Assembly.GetExecutingAssembly();
System.IO.Stream myS = thisExe.GetManifestResourceStream("NameSpaceName.dsoframer.ocx"); string sPath = System.AppDomain.CurrentDomain.BaseDirectory + @"\dsoframer.ocx";
ProcessStartInfo psi = new ProcessStartInfo("regsvr32", "/s " + sPath);
Process.Start(psi);
}
catch (Exception ex)
{
MessageBox.Show(ex.Message);
}
return true;
} //下面这个方法是dso打开文件时需要的一个参数,代表office文件类型
/// <summary>
/// 根据后缀名得到打开方式
/// </summary>
/// <param name="_sExten"></param>
/// <returns></returns>
private string LoadOpenFileType(string _sExten)
{
try
{
string sOpenType = "";
switch (_sExten.ToLower())
{
case "xls":
sOpenType = "Excel.Sheet";
break;
case "doc":
sOpenType = "Word.Document";
break;
case "ppt":
sOpenType = "PowerPoint.Show";
break;
case "vsd":
sOpenType = "Visio.Drawing";
break;
default:
sOpenType = "Word.Document";
break;
}
return sOpenType; }
catch (Exception ex)
{
throw ex;
}
} /// <summary>
/// 第三步:初始化office控件,加载Excel
/// </summary>
/// <param name="_sFilePath">本地文档路径</param>
private void InitOfficeControl(string _sFilePath)
{
try
{
if (m_axFramerControl == null)
{
throw new ApplicationException("请先初始化office控件对象!");
} //this.m_axFramerControl.SetMenuDisplay(48);
//这个方法很特别,一个组合菜单控制方法,我还没有找到参数的规律,有兴趣的朋友可以研究一下
string sExt = System.IO.Path.GetExtension(_sFilePath).Replace(".", "");
//this.m_axFramerControl.CreateNew(this.LoadOpenFileType(sExt));//创建新的文件
this.m_axFramerControl.Open(_sFilePath, false, this.LoadOpenFileType(sExt), "", "");//打开文件
//隐藏标题
this.m_axFramerControl.Titlebar = false;
}
catch (Exception ex)
{
throw ex;
}
} /// <summary>
/// 关闭当前界面
/// </summary>
public void Close()
{
try
{
if (this.m_axFramerControl != null)
{
this.m_axFramerControl.Close();
}
}
catch (Exception ex)
{
throw ex;
}
} //加载Excel 按钮
private void sbtnLoading_Click(object sender, EventArgs e)
{ Init(System.AppDomain.CurrentDomain.BaseDirectory + "excel\\项目汇总表.xls");
} //关闭
private void ExcelForm_FormClosing(object sender, FormClosingEventArgs e)
{
Close();
} #endregion
}

C# Dsoframer.ocx 如何在winform中嵌入Excel,内嵌Excel,word的更多相关文章

  1. C# 如何在winform中嵌入Excel,内嵌Excel,word

    近使用.net做一个小软件遇到一个问题,就是想实现把excel表格在winform中打开,同时可以操作,不单单是打开.或者就提取数据.在网上找了好多资料,发现这方面的资料比较少,即使有,都是旧版本的使 ...

  2. 如何在WinForm中发送HTTP请求

    如何在WinForm中请求发送HTTP 手工发送HTTP请求主要是调用 System.Net的HttpWebResponse方法 手工发送HTTP的GET请 求: string strURL = &q ...

  3. WinForm中嵌入WebBrowser,并且支持C#和JS方法的相互调用

    纯粹WinForm界面不够友好,实现数据复杂度高的处理有些力不从心,所以看了看api以后决定用html来做. 我的wlw的代码插件不是很好用,大家凑合看吧 类前说明引用和权限 1: [Permissi ...

  4. winform中嵌入Ppt、Word、Excel

    1.下载DsoFramer_KB311765_x86.exe 2.安装,默认路径安装C:\DsoFramer. 3.注册:开始菜单——>运行 输入:regsvr32 C:\DsoFramer\d ...

  5. C#实现在Winform中嵌入Word和Excel

    http://www.cnblogs.com/wuzi145/archive/2012/05/08/2490680.html 在此只是介绍一个简单控件:dsoframer.ocx的使用,这个控件需要通 ...

  6. 如何在 Go 中嵌入 Python

    如果你看一下 新的 Datadog Agent,你可能会注意到大部分代码库是用 Go 编写的,尽管我们用来收集指标的检查仍然是用 Python 编写的.这大概是因为 Datadog Agent 是一个 ...

  7. WPF中嵌入Office编辑器(支持Word、Excel、PPT、Visio等)

    现在有一个项目,需要使用wpf做一个简单的客户端,用来生成word.excel.ppt.visio等文档,这就需要能够在wpf中嵌入office的编辑器,并对office文档进行编辑. 在网上搜索了一 ...

  8. 微信小程序中使用 <web-view> 内嵌 H5 时,登录问题的处理方法

    在微信小程序的开发中,经常遇到需要使用 <web-view></web-view> 内嵌 H5 的需求.在这种需求中比较棘手的问题应该就是登录状态的判断了,小程序中的登录状态怎 ...

  9. 如何在 JS 中嵌入大量 HTML 代码 --更新2017-10-10 16:37:09

    一.一般方式 方式1:\ 要写在标签后面,看例子 var longString = "\ ------------------------\ ------------------------ ...

随机推荐

  1. ie 8在打印网页的时候打印预览是空白的

    win 7专业版系统中的ie 8在打印网页的时候打印预览是空白的,打印出来也是空白的,但是用别的浏览器打印没有问题 根据您的描述,该问题主要是由于保护模式下%Temp%\Low不正常工作引起的. 建议 ...

  2. Delphi采用接口实现DLL调用

    Delphi使用模块化开发,可以采用DLL或者BPL,两者的区别是BPL只能被同版本的Delphi使用,DLL可以被不同版本和不同开发工具的开发的软件调用. 因此我们的软件大多使用Delphi作为界面 ...

  3. IO流之字符流

    字符流产生的原因: 1.每次只能够读取一个字节或者一个字节数组,每次在需要转换成字符或者字符串的时候不是很方便2.不同的操作系统针对换行符的处理不方便3.有的时候会出现中文乱码(中文占两个字节,如果针 ...

  4. webpack4的react打包错误

    因为之前一直用的是脚手架创建项目,第一次自己学习创建webpack打包.loader我是复制别人的. module: { loaders: [ { test: /\.js?$/, exclude: / ...

  5. MQTT客户端

    MQTT客户端 最近公司项目中使用到了一个MQTT的协议,用这个通讯协议将嵌入式端收集到的数据接入到物联网中,很是方便的解决了,嵌入式端存储空间小,也解决了用户需要自定义使用这些记录数据的需求.而且相 ...

  6. Lingo基本操作

    目录 Lingo基本操作 前言 一.Lingo基本运算符 1.1 算术运算符 1.2 逻辑运算符 1.3 关系运算符 二.函数 2.1 标准数学函数 2.2 集循环函数 三.待更新 Lingo基本操作 ...

  7. 北京Uber优步司机奖励政策(1月4日)

    滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...

  8. 【LG3527】[POI2011]MET-Meteors

    [LG3527][POI2011]MET-Meteors 题面 洛谷 题解 整体二分. 每次二分\(mid\),如果到时间\(mid\)以收集过\(P_i\)就存入子序列\(L\),否则存入子序列\( ...

  9. 3668: [Noi2014]起床困难综合症

    3668: [Noi2014]起床困难综合症 https://www.lydsy.com/JudgeOnline/problem.php?id=3668 分析: 每一位分开考虑. 算出每一位为1,计算 ...

  10. ORB代码框架梳理

    这里从单目入手,画了一个框架图: