高效率科研神器——数据图表三剑客Mathematica、Excel、Origin(上)

科研工作中数据处理和图表绘制是必不可少的,常用的是Office系列的Excel、Word和PowerPoint以及Origin。这里,笔者引入另一个强大的符号计算软件Mathematica,想通过连接各个软件,使它们能够紧密协作,从而极大的拓展每个软件的功能,提高数据处理和图表绘制效率。

这里的每个软件都是功能十分复杂的大型软件,单个软件都有很多书籍资料来介绍他们的用法,所以这里我想侧重的是如何将各个软件相互联系起来,使它们各取所长、各补所短,发挥1+1大于2的效果。这方面的公开资料非常少,感兴趣的可以查阅以下一些链接,其中的内容后续有时间的话我会进行一些简单的介绍:

·Mathematica和Origin之间的协作

http://www.originlab.com/doc/Origin-Help/ExternalAPP-Mathematica-Link

https://originlab.jira.com/wiki/display/main/Origin+2017+Support+communicate+with+individual+instance+of+Mathematica

·Mathematica和PowerPoint之间的协作

http://reference.wolfram.com/language/howto/CreateASlideShow.html

https://mathematica.stackexchange.com/questions/61/best-way-to-give-presentations-with-mathematica

https://mathematica.stackexchange.com/questions/31511/how-to-include-mathematica-animation-in-a-powerpoint-presentation

http://originlab.com/fileExchange/details.aspx?fid=374

·Mathematica和Excel之间的协作

https://reference.wolfram.com/language/ref/format/XLSX.html

https://www.wolfram.com/products/applications/excel_link/

http://www.wolfram.com/products/applications/excel_link/features/mathematicalink.html

·Origin和PowerPoint之间的协作

http://www.originlab.com/doc/Tutorials/Send-Graphs-to-PPT

·Origin和Excel之间的协作

http://www.originlab.com/doc/Tutorials/BatchProcess-ExcelSummary

http://www.originlab.com/doc/Tutorials/Excel-Connectivity

http://www.originlab.com/doc/Tutorials/Working-with-Excel

这里,我准备首先讨论的是Mathematica和Excel之间的协作。

Mathematica与Excel——ExcelLink插件

Mathematica和Excel都是大型软件,生态丰富、功能繁多,所以这里不介绍单个软件的使用方法,而是侧重于讨论如何同时使用两个软件,以发挥各自的优点。使Mathematica和Excel协同工作的主要方式是通过ExcelLink插件。该插件同时提供一个Mathematica的Package和Excel的Add-in。这样在某一个软件中可以方便的调用另一个软件的功能。下面我们分别来看如何在Mathematica中使用Excel和在Excel中使用Mathematica。

Excel中的ExcelLink插件

在Mathematica中使用Excel

这里不介绍具体的代码,因为这些代码在软件自带的帮助手册里都有,而且代码形式也很简单,这里只介绍能够实现的功能以及主要工作方式。

基本工作方式

在Mathematica使用ExcelLink插件时,需要先导入扩展包,然后打开Excel程序(该程序的ExcelLink工具条需处于开启状态,点击工具条中的第一个按钮确保Mathematica内核已经处于连接状态),接着我们就可以使用一系列以Excel开头的函数来处理我们打开的Excel文件。

最基本的Excel函数参数为Excel文件中的单元格位置,比如A2、B3,也可以通过冒号指定矩形区域,比如“A2:D4”。我们可以直接在Mathematica中赋值、读取,就像一个普通的符号变量一样,而对应的Excel文件中的相应位置会实时发生变化。另外,Mathematica中绘制的函数图形、数学表达式也可以通过直接赋值显示在Excel文件中,我们只需要指定图形左上角所在的单元格就行了。它们都是以图片的形式显示,可以自由调整大小、位置以及更新内容。

主要功能

·Excel文件和工作表的打开、创建、保存等基本操作

·Excel工作表中数据的获取、填充、计算

·根据预定义的模板输出格式化的Excel文件

·在Excel文件中插入Mathematica代码,可以定义成可执行的宏文件。

Tips

·获取A工作表的第二列数据:Rest@Part[ExcelRead@ExcelSheet@”A”,All,2];

需要注意的问题

·如果我们想指定Excel文件中某一单元格内容为Mathematica表达式,那么我们需要指定该单元格的格式为文本,否则Excel软件会对键入的表达式自行做一些处理。这一点我们可以通过Excel插件提供的右键菜单命令来实现,或者通过在Mathematica中使用ExcelFormat函数来指定。

·与上一点相对应的是,如果一个单元格的格式没有指定为文本格式,那么它就被认为是数据。而数据从Excel传递给Mathematica时是按照其内部存储格式——双精度浮点数,而不是按照其显示格式。

·当我们把Mathematica表达式传递给Excel时,表达式会被转化成Excel内部函数的形式,如果没有对应的内部函数,则会以InputForm字符串的形式显示。

在Excel中使用Mathematica

基本工作方式

在Excel中可以像使用普通Excel函数一样使用Mathematica中定义的种类繁多的函数,方法是使用EVAL[“函数名”,参数]的形式,用一层EVAL函数来包裹Mathematica中的函数,非常方便。

对于初学者,如果不熟悉Mathematica中的函数名和赋值方式,该插件提供了一个GUI工具,可以查找函数名,选取数据区域,定义可选变量等,极大的方便了操作。

如果需要在Excel文件中插入整段代码,可以点击工具条中的Macro按钮,直接插入整段的Mathematica代码,并且可以将某单元格定义成按钮,在需要的时候点击按钮执行代码。

插件提供的Mathematica函数查找工具

Tips

·EVAL支持Mathmematica中的虚函数,比如:EVAL("Sum[1)x^#2,{x,#1}]","10","3")

·可以将代码放在某一个工作表中,然后利用Excel自带的隐藏和保护工作表的功能,防止代码被修改。

·ExcelLink插件支持直接在Excel和Mathematica之间复制数据,Mathematica中List格式的数据可以直接转换成Excel中对应的矩阵。如果复制的数据格式未成功转换,可以利用Excel插件中的Clipboard按钮进一步转换。

如何各取所长

和Excel相比,Mathematica在中国的普及率算不上高。这一方面是由于Mathematica自身的原因,比如高昂的售价,生态系统不够丰富,代码速度达不到工业强度等等。但是我认为,对于理科学生来说,Mathematica的优势也是很明显的,主要有以下几点:1.完善的帮助文档,图文并茂、案例详实;2.丰富的格式支持,几乎覆盖绝大多数文档、图像和音视频格式;3.强大的可计算知识库,能够直接查询到种类丰富的知识。对于Mathematica来说,和Excel的联通好处是非常大的,因为Mathematica本身笔记本式的编程方式不利于查看数据,不像MATLAB,可以打开独立的数据窗口,因此,如果我们能够熟练的利用Excel,无意就获得了一个强大无比的数据查看和记录工具,而Excel本身比较薄弱的函数库也可以得到极大补充。

待续:Excel与Origin如何协同工作?

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,772评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,458评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,610评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,640评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,657评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,590评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,962评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,631评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,870评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,611评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,704评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,386评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,969评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,944评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,179评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,742评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,440评论 2 342

推荐阅读更多精彩内容