Excel DDE Commands
! https://zhuanlan.zhihu.com/p/635569763
Excel DDE Commands
连接参数
Application: Excel
Topic:
System: 整个应用。
[sheetname] 指定 worksheet。
我使用的是 .NET 组件 Specshell.NDde
private DdeClient _ddeClient;
public void Init()
{
try
{
_ddeClient = new DdeClient("EXCEL", "System");
_ddeClient.Context.Encoding = System.Text.Encoding.Default;
_ddeClient.Connect();
}
catch (Exception ex)
{
log.Error(ex);
}
}
public void Execute(string cmd, bool needEsc = false)
{
if (needEsc)
{
_ddeClient.TryExecute("[ESC]", 10);
}
_ddeClient.TryExecute(cmd, 5);
}
public void Dispose()
{
try
{
_ddeClient?.Disconnect();
}
catch { }
}
DDE commands
- 命令大小写不敏感(case insensitivity)
- 命令可以带括号,也可以不带括号
[paste]=[paste()]
| Command | 说明 | Description |
|---|---|---|
| Application commands | ||
[app.activate] |
激活应用 | activate the application |
[quit] |
关闭应用 | quit the application |
| Workbook commands | ||
[activate("WorkbookName")] |
激活指定的文档 | activate a workbook |
[new(1)] |
新建一个 workbook | new a workbook |
[open("filepath.xlsx")] |
打开一个 workbook | open a workbook |
[save.as("test1.xlsx")] |
保存文档 | save as a workbook |
[close(false)] |
关闭文档 | close a workbook |
[file.close(false)] |
关闭文档 | close a workbook |
| Worksheet commands | ||
[workbook.select("worksheetName")] |
激活一个 worksheet | activate a worksheet |
[workbook.insert(1)] |
新建一个 worksheet | new a worksheet |
[workbook.prev] |
移动到上一个 worksheet | move to the previous worksheet |
[workbook.next] |
移动到下一个 worksheet | move to the next worksheet |
[workbook.move("", "", 1)] |
移动一个 worksheet | move a worksheet |
[workbook.name("Sheet1", "SheetA")] |
命名一个 worksheet | rename a worksheet |
[workbook.delete("Sheet1")] |
删除一个 worksheet | delete a worksheet |
[workbook.new] |
打开插入对话框 | open the insert dialog |
| data commands | ||
[clear] |
清除当前选择的值 | clear selection values |
[copy] |
复制。 | copy selection values |
[edit.delete][1] |
删除当前选择的单元 | delete selection values |
[esc] |
发送一个 Escape 键? | send the escape key? |
[insert(shiftDirectionAndMode)] |
插入 | insert |
[paste][2] |
粘贴 | paste |
[paste("R1C1")] |
粘贴到指定的单元 | paste to the cells |
[select("R1C1")] |
选择单元 | select cells |
[select("R1:R2")] |
选择行 | select rows |
[select("R[1]:R[1]")] |
相对位置,选择下一行 | select a relative row |
[select("R[1]")] |
相对位置,选择下一行 | select a relative row |
[formula("=formula")] |
设置值 | set a value |
[format.font("Verdana",12)] |
设置字体 | set font |
[patterns(1,0,3)] |
设置单元格式 | set format of cells |
[column.width(20,"c1:c2")] |
设置列宽 | set width of columns |
[column.width(,"c1:c2",false,1)] |
隐藏/显示列 | hide/un-hide columns |
[row.height(20,"r1:r2")] |
设置列宽 | set height of rows |
[row.height(,"r1:r2",false,1)] |
隐藏/显示行 | hide/un-hide rows |
[paste]
不同的选择模式,插入方式不同。单元选择,行选择,列选择,范围选择- 参数:
shiftDirectionAndMode
1- cell move right
2- cell move down
3- row move down
4- column move right
- 参数:
[format.font("Verdana",12,false,false,false,false,4,false,false)]
设置字体。
参数: (font-family, fontname, bold, italic, underline, strikethrough, color index, ?, ?)
color index: 0 ~ 56color index color color 0 automatic ABC 中国 1 #000000 ABC 中国 2 #FFFFFF ABC 中国 3 #0000FF ABC 中国 4 #00FF00 ABC 中国 5 #FF0000 ABC 中国 6 #00FFFF ABC 中国 7 #FF00FF ABC 中国 8 #FFFF00 ABC 中国 9 #000080 ABC 中国 10 #008000 ABC 中国 11 #800000 ABC 中国 12 #008080 ABC 中国 13 #800080 ABC 中国 14 #808000 ABC 中国 15 #C0C0C0 ABC 中国 16 #808080 ABC 中国 17 #FF9999 ABC 中国 18 #663399 ABC 中国 19 #CCFFFF ABC 中国 20 #FFFFCC ABC 中国 21 #660066 ABC 中国 22 #8080FF ABC 中国 23 #CC6600 ABC 中国 24 #FFCCCC ABC 中国 25 #800000 ABC 中国 26 #FF00FF ABC 中国 27 #00FFFF ABC 中国 28 #FFFF00 ABC 中国 29 #800080 ABC 中国 30 #000080 ABC 中国 31 #808000 ABC 中国 32 #FF0000 ABC 中国 33 #FFCC00 ABC 中国 34 #FFFFCC ABC 中国 35 #CCFFCC ABC 中国 36 #99FFFF ABC 中国 37 #FFCC99 ABC 中国 38 #CC99FF ABC 中国 39 #FF99CC ABC 中国 40 #99CCFF ABC 中国 41 #FF6633 ABC 中国 42 #CCCC33 ABC 中国 43 #00CC99 ABC 中国 44 #00CCFF ABC 中国 45 #0099FF ABC 中国 46 #0066FF ABC 中国 47 #996666 ABC 中国 48 #969696 ABC 中国 49 #663300 ABC 中国 50 #669933 ABC 中国 51 #003300 ABC 中国 52 #003333 ABC 中国 53 #003399 ABC 中国 54 #663399 ABC 中国 55 #993333 ABC 中国 56 #333333 ABC 中国 [patterns(1,0,3)]
设置单元。
参数: (pattern, border, background color)[column.width(20,"c1:c2")]
设置列宽。
参数: (columnWidth, columns)) |[column.width(,"c1:c2",false,1)]
隐藏/显示列。
参数: (n/a, columns, ?, (1: hide,2:un-hide))[row.height(20, "r1:r2")]
设置列宽。
参数: (rowHeight, rows)) |[row.height(,"r1:r2",false,1)]
隐藏/显示行。
参数: (n/a, columns, ?, (1: hide,2:un-hide))
Excel DDE Commands的更多相关文章
- Excel,2010,可以独立打开窗口
HKEY_CLASSES_ROOT \ Excel.Sheet.12和HKEY_CLASSES_ROOT\Excel.Sheet.8 首先更改HKEY_CLASSES_ROOT \ Excel.She ...
- VB操作EXCEL文件
用VB操作Excel(VB6.0)(整理) 首先创建Excel对象,使用ComObj:Dim ExcelID as Excel.ApplicationSet ExcelID as new Excel. ...
- Excel 点滴积累
1.Excel中截取邮件@之后的字符 MID(text, start_num, num_chars) FIND(find_text,within_text,start_num) Right(strin ...
- Excel 同时打开2个或多个独立窗口
首先win7版本点击[开始]菜单,在输入框里面输入"regedit.exe"打开注册表 然后定位找到该路径HKEY_CLASSES_ROOT \ Excel.Sheet.1 ...
- 解决Excel 2010只有一个窗口的问题
Excel 2010打开多个文件,但只有一个窗口的问题. 一般首次安装没有这个问题,碰到装了WPS后再卸载WPS,还有就是OFFICE卸载后重装,也会发生这个现像. 一.: 删除 HKEY_CLASS ...
- 浅谈Excel开发:五 Excel RTD函数
上文介绍了Excel中的UDF函数,本文介绍一下同样重要的RTD函数.从Excel 2002开始,Excel引入了一种新的查看和更新实时数据的机制,即real-time data简称RTD函数 ...
- [Office][C#] NPOI、OpenXML SDK、OpenOffice.org SDK 写入资料到 EXCEL 档案[转]
原文地址:http://www.dotblogs.com.tw/chou/archive/2010/04/29/14912.aspx 一.簡介 要將資料寫入 EXCEL 檔案有許多的方法,但假如電腦不 ...
- Formatting Excel File Using Ole2 In Oracle Forms
Below is the some useful commands of Ole2 to format excel file in Oracle Forms.-- Change font size a ...
- 【转】VB中应用DDE
动态数据交换(dde)是windows应用程序间通讯的基本方法之一,在动态数据交换的过程中,提供数据和服务的应用程序称为服务器,请求数据或服务的应用程序则称为客户. dde交谈是由客户程序启动的.如果 ...
- Powerdesigner 导出Excel格式数据字典 导出Excel格式文件
版权声明:本文为博主原创文章,转载请注明出处; 网上我也看到了很多的Powerdesigner 导出方法,因为Powerdesigner 提供了部分VBA功能,所以让我用代码导出Excel格式文件得以 ...
随机推荐
- 云原生K8S精选的分布式可靠的键值存储etcd原理和实践
@ 目录 概述 定义 应用场景 特性 为何使用etcd 术语 架构 原理 读操作 写操作 日志复制 部署 单示例快速部署 多实例集群部署 静态 etcd 动态发现 常见命令 概述 定义 etcd 官网 ...
- new做了哪些事情,手写一个new
1)创建一个空对象,将构造函数中的this指向这个空对象 2)将空对象的__proto__指向构造函数的prototype原型 3)执行构造函数里面的代码,为这个空对象添加属性和方法 4)返回一个新的 ...
- 基于swiper.js的异型轮播
基于原生swiper.js的异型轮播 <div class="swiper-container" > <div class="swiper-wrappe ...
- 关于js类的继承
原型链继承 特点:基于原型链,既是父类的实例,也是子类的实例. 缺点: 无法实现多继承. 构造继承 特点: 可以实现多继承. 缺点: 之能继承父类实例的属性和方法,不能继承原型上的属性和方法. 实例继 ...
- Flask快速入门day 01(flask介绍、快速使用、配置文件、路由系统)
目录 Flask框架 前言: 一.flask介绍 1.介绍 2.使用两种协议编写web 二.flask快速使用 1.快速使用: 2.使用flask编写登录小案例 2.1 login.html 2.2 ...
- pandas之reindex重置索引
重置索引(reindex)可以更改原 DataFrame 的行标签或列标签,并使更改后的行.列标签与 DataFrame 中的数据逐一匹配.通过重置索引操作,您可以完成对现有数据的重新排序.如果重置的 ...
- Java设计模式 —— 建造者模式
8 建造者模式 8.1 建造者模式概述 Builder Pattern:将一个复杂对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示. 建造者模式可以将部件本身和它们的组装过程分开,关注如 ...
- 为什么C++语言性能优越?
面试时被问到这个问题,发现自己一直以来理所当然的认为C++快,却没有具体分析原因.下面简单总结一下为什么快. 当我们编写程序时,我们需要将程序转换为计算机可以理解的机器语言.不同的语言有不同的执行机制 ...
- ShardingJDBC配置
Sharding-JDBC定位为轻量级Java框架,在Java的JDBC层提供的额外服务. 它使用客户端直连数据库,以jar包形式提供服务,无需额外部署和依赖,可理解为增强版的JDBC驱动,完全兼容J ...
- 【ACM算法竞赛日常训练】DAY16【奇♂妙拆分】【区区区间间间】【小AA的数列】数学 | 位运算 | 前缀和
DAY16共3题: 奇♂妙拆分(简单数学) 区区区间间间(单调栈) 小AA的数列(位运算dp) 作者:Eriktse 简介:19岁,211计算机在读,现役ACM银牌选手力争以通俗易懂的方式讲解算法!️ ...