excel二次开发教程
Excel二次开发在工程物资管理中的应用
香智能管理134智能城市INTELLIGENT CITY NO.122020Excel二次开发在工程物资管理中的应用田静(长安大学建筑工程学院,陕西西安710061)摘要:ExcelA—款已经被广泛接受的办公软件,其功用性和兼容性都非常强大。
但是在日常使用中,很多功能并不能被直接使用,需要依赖Excel自带的VBA来解决,但VBA对于编码领域以外的人员难度较大,故文章以软件二次开发为思路,以操作简便为前提,着重讲述Excel二次开发在工程物资管理中的一些应用。
关键字:Excel;二次开发;物资管理1物资管理中Excel二次开发的必要性建筑工程项目的利润空间取决于企业的管理水平。
在建筑安装工程费的各子项目中,材料费的占比高达60%~70%,物资材料的管理不仅关乎工程的质量、安全、进度,也体现着Y项目的管理水平,决定着该项目的利润率。
所以利用新思想、新技术使物资管理电子化、效率化,可以提高项目的管理水平。
传统的物资管理,涉及计划、合同、采购、检验、储运、入库保管、出库、对账,其中入库与出库需要详尽的台账记录,对账与数据分析也需要耗费大量的人力、物力和时间,这些重复性工作的处理方法也亟须被优化,若转换为电子化处理,精确度也会有很大提升。
由于物资管理会涉及彳艮多不同的企业,市面上的管理软件就会存在兼容不佳的问题,故Excel还是目前处理相关数据的最佳选择。
2Exceir次开发实操方法对Excel进行二次开发,服务于物资管理的相关数据处理,可以极大地提高办公的效率和准确度,也可提高Excel 的利用率。
本文所述的二次开发,即是将Excel的基础功能与宏结合,下文从核对入库、出库和混凝土用量数据分析两个方面,详细阐述该思路的实操方法。
2.1Excel宏与函数结合在每一个对账周期期末,入库与出库的登记台账需要进行比对,两份台账的明细顺序一般都是不一致的,查找比对起来很困难,但是两份台账肯定有订单编号或者运送编号是一致的,传统对账也是根据该唯_确定值来进行台账的核对。
专业级Excel VBA培训课程:用VBA进行Excel二次开发
专业级Excel VBA培训课程:用VBA进行Excel二次开发课程简介--------------------------------------------------------------------------------本课程系统讲述了Excel VBA开发的基本概念、VBA语言、Excel对象模型、应用Excel 和VBA进行数据处理、Excel图表的VBA编程、用户窗体和Excel工作表界面设计、开发效率、互操作、API调用等高级话题;并结合3个实际案例,介绍了如何在工作实际中使用VBA和Excel提高工作效率,设计Excel VBA应用程序。
培训对象--------------------------------------------------------------------------------本课程适用于想通过Excel VBA来提高工作效率,使用Excel和VBA作为开发和数据处理平台的人。
培训大纲--------------------------------------------------------------------------------第1章Excel和VBA简介1.1 关于Excel和VBA1.2 Excel作为数据处理平台1.3 Excel作为开发平台1.4 宏、加载宏和VBA第1部分入门篇第2章Excel与宏2.1 宏2.2 录制宏2.2.1 宏的录制步骤2.2.2 录制宏的一个小例子2.3 运行宏2.3.1 运行录制的宏2.3.2 将宏加入菜单或工具栏2.4 查看和编辑宏2.5 加载宏第3章VBA初步3.1 VBA简介3.2 VBA快速入门3.2.1 VBA开发环境3.2.2 VBA工程及其组成3.2.3 编写代码3.2.4 模块、过程和函数3.2.5 创建过程和函数3.2.6 过程调用3.2.7 变量3.2.8 程序流程3.2.9 条件语句3.2.10 循环语句3.2.11 数组3.2.12 善用工具及其他3.3 应用VBA操作Excel3.3.1 Excel对象模型3.3.2 Excel对象模型中的常用对象3.4 应用实例3.4.1 使用VBA合并列3.4.2 自动隐藏或显示表格中无数据的行3.4.3 使用VBA操作工作表单元格3.4.4 查找工作表的第一个空行3.4.5 改变Excel界面的标题3.4.6 隔行格式化工作表3.4.7 批量修改数据第4章应用VBA自定义函数4.1 公式和函数4.1.1 公式及其组成4.1.2 引用4.1.3 名称和常量4.1.4 运算符和运算次序4.2 Excel工作表函数4.2.1 常用函数4.2.2 统计函数4.2.3 数组公式4.3 自定义函数4.3.1 创建自定义函数4.3.2 创建数组公式4.4 应用实例4.4.1 成绩统计辅助函数4.4.2 身份证号码处理函数第2部分进阶篇第5章VBA语言5.1 VBA程序的组成5.1.1 模块5.1.2 过程5.1.3 函数5.1.4 过程和函数调用5.1.5 注释5.2 数据类型5.2.1 常量和变量5.2.2 数据类型5.2.3 运算符5.2.4 数组5.2.5 自定义数据类型5.2.6 枚举类型5.2.7 变量的作用域(生存周期)5.2.8 字符串5.2.9 日期和时间5.3 控制程序流程5.3.1 条件语句5.3.2 循环语句5.3.3 With语句5.3.4 Exit语句5.4 简单的用户交互5.5 用户窗体。
NX二次开发-基于NX开发向导模板的NX对Excel读写操作(OLE方式(COM组件))
NX⼆次开发-基于NX开发向导模板的NX对Excel读写操作(OLE⽅式(COM组件))版本NX11+VS2013+office2016⾸先我们通过NX开发向导创建了⼀个模板。
先把项⽬属性改成多字节。
下⾯我们把前⾯做的MFC项⽬⾥的⼏个EXCAL头⽂件和stdafx⼀块拷过来,加到NX的项⽬⾥。
在NX的CPP⾥加上#include "stdafx.h"头⽂件编译出现如下问题,把stdafx.h"头⽂件⾥的//#include "targetver.h"注释掉,在编译。
出现 warning C4003: “CreateDialogW”宏的实参不⾜,双击报错问题,跳转到对应代码位置。
把CreateDialog前加_下划线。
(不要问我为什么这么做,我解释不出来),反正你在编译就通过了。
同时也不当误⽤Block UI到这⾥这个操作EXCAL的项⽬搭建就完事了。
去⾃⼰定义的回调函数⾥,直接写操作EXCAL的代码就⾏了。
下⾯是打开EXCAL,读取内容的⼀个简单例⼦。
写在模板的do_it⾥1 LPDISPATCH lpDisp;2 COleVariant vResult;3 COleVariant4 covTrue((short)TRUE),5 covFalse((short)FALSE),6 covOptional((long)DISP_E_PARAMNOTFOUND, VT_ERROR);78if (!App.CreateDispatch("Excel.Application"))9 {10 uc1601("创建Excel实例失败", 1);11 }121314 App.put_Visible(TRUE); //使Excel可见15 App.put_UserControl(TRUE);16 App.put_DisplayAlerts(false);1718 Books.AttachDispatch(App.get_Workbooks());192021//打开EXCAL22 lpDisp = Books.Open("D:\\ABC.xlsx", covOptional, covOptional, covOptional, covOptional, covOptional, covOptional, covOptional, covOptional,23 covOptional, covOptional, covOptional, covOptional, covOptional, covOptional);24 Book.AttachDispatch(lpDisp);252627//得到Worksheets28 lpDisp = Book.get_Worksheets();29 sheets.AttachDispatch(lpDisp);3031//获得Sheet的数量32int count = sheets.get_Count();3334for (int k = 1; k <= count; k++)35 {36 _variant_t var = (long)k;37 sheet.AttachDispatch(sheets.get_Item(var));3839if (sheet.get_Name() == "DEF")40 {41 sheet.Activate();4243//获得活动的WorkSheet(⼯作表)44 sheet.AttachDispatch(Book.get_ActiveSheet(), TRUE);4546//获得使⽤的区域Range(区域)47 range.AttachDispatch(sheet.get_UsedRange(), TRUE);4849//获得使⽤的⾏数50long lgUsedRowNum = 0;51 range.AttachDispatch(range.get_Rows(), TRUE);52 lgUsedRowNum = range.get_Count();5354//获得使⽤的列数55long lgUsedColumnNum = 0;56 range.AttachDispatch(range.get_Columns(), TRUE);57 lgUsedColumnNum = range.get_Count();5859//读取Sheet名称60 CString strSheetName = sheet.get_Name();6162//得到全部Cells,此时,userRange是cells的集合63 range.AttachDispatch(sheet.get_Cells(), TRUE);646566//遍历整个Excel表格67double Date1;68 CString str1;69for (int j = 1; j <= lgUsedRowNum; j++)70 {71for (int i = 1; i <= lgUsedColumnNum; i++)72 {73 CString str;74 str.Format("%c%d", 65 + i - 1, j);75 lpDisp = range.get_Range(COleVariant(str), COleVariant(str)); 7677 CRange range;78 range.AttachDispatch(lpDisp);7980 VARIANT vl = range.get_Value2();818283if (vl.vt == VT_R8) //8字节的数字84 {8586 Date1 = vl.dblVal;87char msg[256];88 sprintf_s(msg, "%f", Date1);8990 uc1601(msg, 1);91 }9293if (vl.vt == VT_BSTR) //字符串94 {9596 str1 = vl.bstrVal;9798 uc1601(str1, 1);99100 }101 }102103 }104105 }106 }107108109110//释放对象,关闭EXCEL111//range.ReleaseDispatch();112//sheet.ReleaseDispatch();113//sheets.ReleaseDispatch();114//Book.Close(covOptional, covOptional, covOptional);115//Book.ReleaseDispatch();116//Books.Close();117//Books.ReleaseDispatch();118//App.Quit();119//App.ReleaseDispatch();。
EXCEL二次开发制作统计地图工具及其应用_陆健
பைடு நூலகம்
J iangsu Health Care,Oct. 2014,Vol. 16,No. 5
口病的防控重点是 < 5 岁儿童和散居儿童。 病原学监测发现,2008—2013 年金坛市手足口
病以 EV71、CoxA16 为主,共占通用阳性标本的 68. 57% 。值得注意的是,其他肠道病毒感染占通用阳性 标本的 比 例 由 2010 年 的 8. 33% 提 高 到 2013 年 的 71. 21% ,超过 EV71 和 CoxA16,成为 2012—2013 年 主要的病毒株,应引起重点关注。
. Shapes( " Picture 1" ) . Formula = " 样表! S| AS| 6 ∶ S| KS| 42 将 数 据 分 档 值 及 底 色 图 样 显 示 到 地 图 右
下方
江苏卫生保健 2014 年 10 月第 16 卷第 5 期
·25·
End Sub∥结束运行代码 1. 5 运行代码实现统计地图功能 可以从工具宏中 找到 tjdt 点执行即可生成统计地图,也可以在 sheet1 地图旁边设一个控件按钮,通过点击按钮来运行代码。
【疾 病 防 治 】
櫧櫧櫧櫧櫧櫧櫧櫧櫧櫧櫧櫧櫧櫧櫧櫧櫧毥
櫧毥
EXCEL 二次开发制作统计地图工具及其应用
陆健,王银存 江苏省大丰市疾病预防控制中心,盐城 224100
摘要: 利用 Excel vba 具有的强大的数据处理及图形显示功能,绘制图形,编制代码模块,开发 统计地图软件工具,实现由数据到图形色彩深浅的自动转化,以了解疾病或健康危害因素在不同 地区的分布情况,掌握其地理危险因素,为更好地开展针对性的防治措施提供依据。 关键词: 统计地图; 软件工具; Excel vba 应用实例 中图分类号: 文献标识码: B 文章编号: 1008 - 7338( 2014) 05 - 0024 - 02
基于VBA对Excel 2007二次开发应用研究
基于VBA对Excel 2007二次开发应用研究作者:刘铭来源:《现代电子技术》2010年第10期摘要:Excel 2007在日常办公方面应用较普遍,但是在合并多个单元格时,只能保留选择区域最左上角的单元格数据,其他单元格的数据将被丢弃。
针对工作中在合并单元格时,需要保留选择区域所有单元格的数据,在此提出基于VBA对二次开发,结合Excel 2007对象模型Application对象的属性,设计合并单元格控件的方法。
在 e 2007环境下,设计并开发出控件,实现了合并多个单元格,保留选择区域数据,解决了工作中的实际问题。
关键词:VBA; 二次开发; Excel 2007; 合并单元格中图分类号:TP311 文献标识码:B文章编号:1004-373X(2010)10-0055-03VBA-based Secondary Development of Excel 2007LIU Ming(Chongqing Vocational Institute of Engineering, Chongqing400037, China)Abstract:Excel 2007 has been widely applied in peoptes daily life, but there are also some problems. When merging multiple cells, justthe cells on the very top left can be maintained andall the other cells are deleted. However, All the data of the cells in the selected area need be kept during the mergence of cells. The re-development of Excel 2007 is proposed based on VBA. The control widget of merging the cells is designed in combination with Excel 2007 objective mode and application object′s properties. Under the condition ofWindows XP SP3+Office 2007, the merging of multiple cells and the keeping of data in theselecting area are implemented by designing and developing control widget.Keywords:VBA; redevelopment; Excel 2007; cell mergence0 引言Microsoft Office已作为企事业单位解决办公自动化的理想的工具。
NX二次开发-C#NPOI库读写EXCEL
NX⼆次开发-C#NPOI库读写EXCEL 引⼊NPOI库NX9+VS2012using System;using NXOpen;using NXOpen.UF;using NPOI;using erModel;using erModel;using erModel;using System.IO;public class Program{// class membersprivate static Session theSession;private static UI theUI;private static UFSession theUfSession;public static Program theProgram;public static bool isDisposeCalled;//------------------------------------------------------------------------------// Constructor//------------------------------------------------------------------------------public Program(){try{theSession = Session.GetSession();theUI = UI.GetUI();theUfSession = UFSession.GetUFSession();isDisposeCalled = false;}catch (NXOpen.NXException ex){// ---- Enter your exception handling code here -----// UI.GetUI().NXMessageBox.Show("Message", NXMessageBox.DialogType.Error, ex.Message);}}//------------------------------------------------------------------------------// Explicit Activation// This entry point is used to activate the application explicitly//------------------------------------------------------------------------------public static int Main(string[] args){int retValue = 0;try{theProgram = new Program();//TODO: Add your application code here//读取EXCEL//路径string path = "D:\\3DPNG\\123.xlsx";//读取FileStream fs = File.OpenRead(path);IWorkbook wk = new XSSFWorkbook(fs);theUfSession.Ui.OpenListingWindow();//获得所有sheetfor (int i = 0; i < wk.NumberOfSheets; i++){//读取当前表数据ISheet sheet = wk.GetSheetAt(i);theUfSession.Ui.WriteListingWindow("sheet" + i.ToString() + "所有内容");theUfSession.Ui.WriteListingWindow("\n");//获取所有⾏for (int j = 0; j <= stRowNum; j++){IRow row = sheet.GetRow(j);//读取当前⾏数据if (row != null){//获得当前⾏的所有列for (int k = 0; k < stCellNum; k++){//读取单元格数据(⾏和列)ICell cell = sheet.GetRow(j).GetCell(k);//打印theUfSession.Ui.WriteListingWindow(cell.ToString());theUfSession.Ui.WriteListingWindow(",");}}theUfSession.Ui.WriteListingWindow("\n");}}fs.Close();//新建写⼊EXCEL//路径string path1 = "D:\\3DPNG\\456.xlsx";//创建EXCELFileStream fs2 = File.Create(path1);IWorkbook wk2 = new XSSFWorkbook();//创建sheetISheet sheet1 = wk2.CreateSheet("A");ISheet sheet2 = wk2.CreateSheet("B");//写⼊内容ICell tmpCell1 = sheet1.CreateRow(1).CreateCell(1);tmpCell1.SetCellValue("这是sheet1!");ICell tmpCell2 = sheet2.CreateRow(1).CreateCell(1);tmpCell2.SetCellValue("这是sheet2");//设置当前sheetwk2.SetActiveSheet(1);//将图⽚添加到workbook中指定图⽚格式返回图⽚所在workbook->Picture数组中的索引地址(从1开始)string PngPath = "D:\\3DPNG\\1.png";byte[] byteArray = System.IO.File.ReadAllBytes(PngPath);int pictureIdx = wk2.AddPicture(byteArray, PictureType.PNG);//在sheet2中创建画布IDrawing patriarch = sheet2.CreateDrawingPatriarch();//设置锚点(在起始单元格的X坐标0-1023,Y的坐标0-255,在终⽌单元格的X坐标0-1023,Y的坐标0-255,起始单元格⾏数,列数,终⽌单元格⾏数,列数) IClientAnchor anchor = patriarch.CreateAnchor(0, 0, 0, 0, 5, 5, 20, 20);//创建图⽚IPicture pict = patriarch.CreatePicture(anchor, pictureIdx);//⾃动调节图⽚⼤⼩//pict.Resize();//另存为wk2.Write(fs2);fs2.Close();theProgram.Dispose();}catch (NXOpen.NXException ex){// ---- Enter your exception handling code here -----}return retValue;}//------------------------------------------------------------------------------// Following method disposes all the class members//------------------------------------------------------------------------------public void Dispose(){try{if (isDisposeCalled == false){//TODO: Add your application code here}isDisposeCalled = true;}catch (NXOpen.NXException ex){// ---- Enter your exception handling code here -----}}public static int GetUnloadOption(string arg){//Unloads the image explicitly, via an unload dialog//return System.Convert.ToInt32(Session.LibraryUnloadOption.Explicitly);//Unloads the image immediately after execution within NXreturn System.Convert.ToInt32(Session.LibraryUnloadOption.Immediately);//Unloads the image when the NX session terminates// return System.Convert.ToInt32(Session.LibraryUnloadOption.AtTermination); }}Caesar卢尚宇2020年8⽉16⽇。
NX二次开发-基于MFC界面的NX对Excel读写操作(OLE方式(COM组件))
NX⼆次开发-基于MFC界⾯的NX对Excel读写操作(OLE⽅式(COM组件))EXCAL操作(⼀)打开写⼊新建⼀个MFC项⽬点击下⼀步选择基于对话框直接点完成,进来后如下图先点项⽬,右键属性,更改为多字节。
先什么都不动,编译⼀下代码。
默认看能不能通过。
然后点项⽬,右键类向导。
弹出窗⼝如下点击添加类-类型库中的MFC类弹出如下我们切换到⽂件,点击添加。
此处添加要找到的⽂件就是你电脑上装的EXCAL.exe这个程序⽂件。
如果你不知道怎么找到的话,有⼀个⽅法,先去开始菜单找到你的EXCAL快捷⽅式,然后在点右键,打开⽂件所在的位置。
这样就找到了。
下⾯在回到MFC项⽬⾥⾯,我们选中这个⽂件。
添加进来之后,如图所⽰。
左侧为EXCAL给出的接⼝,我们来选择⼀些需要的添加进来。
我们就先添加这七个,后续有其他需求在添加其他的。
(先在左侧接⼝⾥选中⼀个,点中间的>就能添加到右侧⾥⽣成的类⾥,不想要就在点中间的<撤退回去。
)然后我们点完成,点确定。
就看到头⽂件⾃动添加进来了。
我们点击新增进来的EXCAL每个头⽂件,都把第⼀⾏的那句注释掉。
都注释完之后,我们在#include "stdafx.h"⾥添加EXCAL头⽂件,然后编译代码,出现如下报错问题。
这时我们双击这个错误,跳到对应的代码那⾥。
有问题的位置如下我们需要在DialogBox前⾯加上⼀个 _ 下划线。
再去编译就通过了。
别问我为什么,我答不上来,你照着搞就是了,别⼈就是这么搞的。
好的,到这⾥我们这个项⽬环境就算搭建完成了。
下⾯可以写代码了。
点击MFC那个对话框界⾯,双击确定。
在⾥⾯写代码。
代码如下:打开EXCAL,写⼊内容。
1//1.创建基本对象2 CApplication App; //创建应⽤程序实例3 CWorkbooks Books; //⼯作簿,多个Excel⽂件4 CWorkbook Book; //单个⼯作簿5 CWorksheets sheets;//多个sheet页⾯6 CWorksheet sheet; //单个sheet页⾯7 CRange range; //操作单元格8//2.打开指定Excel⽂件,如果不存在就创建9char path[MAX_PATH];10 GetCurrentDirectory(MAX_PATH, (TCHAR*)path);//获取当前路径11 CString strExcelFile = (TCHAR*)path;12 CString strdevName = _T("\\Test.xlsx"); //xls也⾏13 strExcelFile += strdevName;14 COleVariant15 covTrue((short)TRUE),16 covFalse((short)FALSE),17 covOptional((long)DISP_E_PARAMNOTFOUND, VT_ERROR);1819 LPDISPATCH lpdisp = NULL;20//1.创建Excel实例21if (!App.CreateDispatch(_T("Excel.Application"), NULL))22 {23 AfxMessageBox(_T("创建Excel实例失败"));24 exit(-1);25 }26else27 {28 AfxMessageBox(_T("创建成功"));29 }30 App.put_Visible(TRUE); //打开Excel31 App.put_UserControl(FALSE);32//2. 得到workbooks容器33 Books.AttachDispatch(App.get_Workbooks());34 Book.AttachDispatch(Books.Add(covOptional));35 sheets.AttachDispatch(Book.get_Worksheets());36 sheet.AttachDispatch(sheets.get_Item(COleVariant((short)1))); //获取sheet137 sheet.put_Name(_T("TestName")); //设置sheet1名字3839//3. 加载要合并的单元格40 range.AttachDispatch(sheet.get_Range(COleVariant(_T("B2")), COleVariant(_T("E2"))), TRUE);41 range.Merge(COleVariant((long)0)); //合并单元格4243//4. 设置表格内容44 range.AttachDispatch(sheet.get_Cells(), TRUE); //加载所有单元格45 range.put_Item(COleVariant((long)2), COleVariant((long)2), COleVariant(_T("电⽓⼯程及其⾃动化课程统计")));46 range.put_Item(COleVariant((long)3), COleVariant((long)2), COleVariant(_T("课程名称")));47 range.put_Item(COleVariant((long)3), COleVariant((long)3), COleVariant(_T("课时")));48 range.put_Item(COleVariant((long)3), COleVariant((long)4), COleVariant(_T("难度")));49 range.put_Item(COleVariant((long)3), COleVariant((long)5), COleVariant(_T("教学⽅式")));5051 range.put_Item(COleVariant((long)4), COleVariant((long)2), COleVariant(_T("电磁场")));52 range.put_Item(COleVariant((long)4), COleVariant((long)3), COleVariant(_T("30")));53 range.put_Item(COleVariant((long)4), COleVariant((long)4), COleVariant(_T("变态难")));54 range.put_Item(COleVariant((long)4), COleVariant((long)5), COleVariant(_T("⽼师讲课")));5556 range.put_Item(COleVariant((long)5), COleVariant((long)2), COleVariant(_T("电机学")));57 range.put_Item(COleVariant((long)5), COleVariant((long)3), COleVariant(_T("40")));58 range.put_Item(COleVariant((long)5), COleVariant((long)4), COleVariant(_T("难")));59 range.put_Item(COleVariant((long)5), COleVariant((long)5), COleVariant(_T("⽼师讲课加实验")));6061 range.put_Item(COleVariant((long)6), COleVariant((long)2), COleVariant(_T("PLC")));62 range.put_Item(COleVariant((long)6), COleVariant((long)3), COleVariant(_T("20")));63 range.put_Item(COleVariant((long)6), COleVariant((long)4), COleVariant(_T("普通")));64 range.put_Item(COleVariant((long)6), COleVariant((long)5), COleVariant(_T("⽼师讲课加实验")));656667 range.put_Item(COleVariant((long)7), COleVariant((long)2), COleVariant(_T("电⼒系统")));68 range.put_Item(COleVariant((long)7), COleVariant((long)3), COleVariant(_T("50")));69 range.put_Item(COleVariant((long)7), COleVariant((long)4), COleVariant(_T("难")));70 range.put_Item(COleVariant((long)7), COleVariant((long)5), COleVariant(_T("⽼师讲课加实验")));7172 range.AttachDispatch(sheet.get_UsedRange());//加载已使⽤的单元格73 range.put_WrapText(COleVariant((long)1)); //设置⽂本⾃动换⾏7475//5.设置对齐⽅式76//⽔平对齐:默认 1 居中 -4108,左= -4131,右=-415277//垂直对齐:默认 2 居中 -4108,左= -4160,右=-410778 range.put_VerticalAlignment(COleVariant((long)-4108));79 range.put_HorizontalAlignment(COleVariant((long)-4108));80//6.设置字体颜⾊81 CFont0 ft;82 ft.AttachDispatch(range.get_Font());83 ft.put_Name(COleVariant(_T("楷体"))); //字体84 ft.put_ColorIndex(COleVariant((long)1));//颜⾊ //⿊⾊85 ft.put_Size(COleVariant((long)12)); //⼤⼩8687 range.AttachDispatch(sheet.get_Range(COleVariant(_T("B2")), COleVariant(_T("E2"))), TRUE);88 ft.AttachDispatch(range.get_Font());89 ft.put_Name(COleVariant(_T("华⽂⾏楷")));90 ft.put_Bold(COleVariant((long)1));91 ft.put_ColorIndex(COleVariant((long)5)); //颜⾊92 ft.put_Size(COleVariant((long)18)); //⼤⼩93 Book.SaveCopyAs(COleVariant(strExcelFile)); //保存9495 Book.put_Saved(TRUE);96//8.释放资源97 range.ReleaseDispatch();98 sheet.ReleaseDispatch();99 sheets.ReleaseDispatch();100 Book.ReleaseDispatch();101 Books.ReleaseDispatch();102 App.ReleaseDispatch();编译后,我们点调试-开始执⾏。
EXCEL二次开发的三种方式
一、VBA的内部开发所谓内部开发,指的是使用EXCEL内嵌的VBA来开发。
可以把VBA 看作是VB的一个子集,二者在数据定义、结构设计、语法使用上都是一致的。
只不过VBA不能脱离EXCEL来运行,VB可以开发在Windows下运行的程序,而VBA只是让EXCEL自动化。
VBA有自己的IDE集成开发环境,用户可以通过“工具”菜单,选择“宏”,选择VB编辑器来打开VBA开的集成环境。
在IDE中,用户可以创建、修改、运行、编辑和调试自己的程序。
熟悉了开发环境之后,我们就可以编写代码了。
如:“Cells(1,1)=100“,Cells是EXCEL的单元格对象,此语句的功能是对第一行第一列的单元格赋值,运行后,此单元格内就会显示为100。
又如:在”Application.Cursor=xlWait“语句中,Application代表EXCEL本身,它是EXCEL的最高级对象,本语句的功能是将EXCEL的鼠标形状设置为等待形(沙漏形)。
用VBA进行EXCEL的二次开发,简单、方便、效率高,并且用它开发的程序也可以使用自己设计的界面(窗体),把数据存放在EX2CEL的单元格中。
不过它不能单独发布,也很容易被人破解。
如果想让自己的程序能够发布,变成商业软件,那么可以采取下面两种方式。
二、COM插件开发所谓的COM,是ComponentObjectModel的缩写,是组件对象模型的意思, COM 插件也叫COM加载项,实际上是一个动态链接库,我们可以开发程序作为一个链接库链接到一些程序中,从而扩展其功能。
例如, IE浏览器就经常被添加加载项。
关于如何使用COM 开发Excel的组件,请看我的另一篇文章“如何使用VB编写Excel 的COM组件”,COM组件比较适合个人制作的小软件,通常的COM插件是没有自己的界面的,只是在宿主应用程序中集成一个菜单或者命令条。
然后等待响应。
三、自动化服务开发自动化使应用程序能够对另一个应用程序中实现的对象进行操作,或者将对象公开以便可以对其进行操作。
ecel的vb二次开发方法
用VB操作excel方法汇总Private Sub Command3_Click()Dim i As LongDim j As LongDim objExl As '声明对象变量= 11 '改变鼠标样式Set objExl = New '初始化对象变量= 1 '将新建的工作薄数量设为1'增加一个工作薄= "book1" '修改工作薄名称, ("book1") '增加第二个工作薄在第一个之后= "book2", ("book2") '增加第三个工作薄在第二个之后= "book3"("book1").Select '选中工作薄<book1>For i = 1 To 50 '循环写入数据For j = 1 To 5If i = 1 Then= "@" '设置格式为文本(i, j) = " E " & i & jElse(i, j) = i & jEnd IfNextNext("1:1").Select '选中第一行= True '设为粗体= 24 '设置字体大小'自动调整列宽= 1 '拆分第一行= 0 '拆分列= True '固定拆分= "$1:$1" '设置打印固定行= "" '打印标题= "打印时间: " & _Format(Now, "yyyy年mm月dd日hh:MM:ss")= xlPageBreakPreview '设置显示方式= 100 '设置显示大小'给工作表加密码"123", DrawingObjects:=True, _Contents:=True, Scenarios:=True= False= True '使EXCEL可见= xlMaximized 'EXCEL的显示方式为最大化= xlMaximized '工作薄显示方式为最大化= 3 '将默认新工作薄数量改回3个Set objExl = Nothing '清除对象= 0 '修改鼠标Exit SubEnd Sub全面控制 Excel首先创建 Excel 对象,使用ComObj:Dim ExcelID asSet ExcelID as new1) 显示当前窗口: := True;2) 更改 Excel 标题栏: := '应用程序调用 Microsoft Excel';3) 添加新工作簿:4) 打开已存在的工作簿: 'C:\Excel\' );5) 设置第2个工作表为活动工作表:[2].Activate;或 [ 'Sheet2' ].Activate;6) 给单元格赋值:[1,4].Value := '第一行第四列';7) 设置指定列的宽度(单位:字符个数),以第一列为例::= 5;8) 设置指定行的高度(单位:磅)(1磅=厘米),以第二行为例::= 1/; ows[8].PageBreak := 1;10) 在第8列之前删除分页符::= 0;11) 指定边框线宽度:'B3:D4' ].Borders[2].Weight := 3;1-左 2-右3-顶 4-底5-斜( \ ) 6-斜( / )12) 清除第一行第四列单元格公式:13) 设置第一行字体属性::= '隶书';:= clBlue;:= True;:= True;14) 进行页面设置:a.页眉: := '报表演示';b.页脚: := '第&P页';c.页眉到顶端边距2cm: := 2/;d.页脚到底端边距3cm: := 3/;e.顶边距2cm: := 2/;f.底边距2cm: := 2/;g.左边距2cm: := 2/;h.右边距2cm: := 2/;i.页面水平居中: := 2/;j.页面垂直居中: := 2/;k.打印单元格网线: := True;15) 拷贝操作:a.拷贝整个工作表:b.拷贝指定区域: 'A1:E2' ].Copy;c.从A1位置开始粘贴: 'A1' ].PasteSpecial;d.从文件尾部开始粘贴:16) 插入一行或一列:a.b.17) 删除一行或一列:a.b.18) 打印预览工作表:19) 打印输出工作表:20) 工作表保存:If not thenEnd if21) 工作表另存为:FileName:="C:\Excel\"22) 放弃存盘::= True;23) 关闭工作簿:24) 退出 Excel:;25) 设置工作表密码:"123", DrawingObjects:=True, Contents:=True, Scenarios:=True26) EXCEL的显示方式为最大化= xlMaximized27) 工作薄显示方式为最大化= xlMaximized28) 设置打开默认工作薄数量= 329) '关闭时是否提示保存(true 保存;false 不保存)= False30) 设置拆分窗口,及固定行位置= 1= True31) 设置打印时固定打印内容= "$1:$1"32) 设置打印标题= ""33) 设置显示方式(分页方式显示)= xlPageBreakPreview34) 设置显示比例= 100Excel 语句集300定制模块行为(1) Option Explicit '强制对模块内所有变量进行声明Option Private Module '标记模块为私有,仅对同一工程中其它模块有用,在宏对话框中不显示 Option Compare Text '字符串不区分大小写Option Base 1 '指定数组的第一个下标为1(2) On Error Resume Next '忽略错误继续执行VBA代码,避免出现错误消息(3) On Error GoTo ErrorHandler '当错误发生时跳转到过程中的某个位置(4) On Error GoTo 0 '恢复正常的错误提示(5) =False '在程序执行过程中使出现的警告框不显示(6) =False '关闭屏幕刷新=True '打开屏幕刷新(7) '禁用Ctrl+Break中止宏运行的功能工作簿(8) () '创建一个新的工作簿(9) Workbooks(“”).Activate '激活名为book1的工作簿(10) '保存工作簿(11) '关闭当前工作簿(12) '获取活动工作薄中工作表数(13) '返回活动工作薄的名称(14) ‘返回当前工作簿名称‘返回当前工作簿路径和名称(15) =False ‘禁止调整活动工作簿的大小(16) xlArrangeStyleTiled ‘将工作簿以平铺方式排列(17) =xlMaximized ‘将当前工作簿最大化工作表(18) ‘当前工作表中已使用的行数(19) ‘获取工作表的行数(注:考虑向前兼容性)(20) Sheets(Sheet1).Name= “Sum” '将Sheet1命名为Sum(21) Before:=Worksheets(1) '添加一个新工作表在第一工作表前(22) After:=ActiveWorkbook. _Sheets '将当前工作表移至工作表的最后(23) Worksheets(Array(“sheet1”,”sheet2”)).Select '同时选择工作表1和工作表2(24) Sheets(“sheet1”).Delete或 Sheets(1).Delete '删除工作表1(25) (i).Name '获取工作表i的名称(26) =Not '切换工作表中的网格线显示,这种方法也可以用在其它方面进行相互切换,即相当于开关按钮(27) =Not ‘切换工作表中的行列边框显示(28) ‘删除当前工作表中所有的条件格式(29) ‘取消当前工作表所有超链接(30)或 '将页面设置更改为横向(31) ‘在页面设置的表尾中输入文件路径‘将用户名放置在活动工作表的页脚单元格/单元格区域(32)或Range(xlUp),(xlDown)).Select'选择当前活动单元格所包含的范围,上下左右无空行(33) ‘选定当前工作表的所有单元格(34) Range(“A1”).ClearContents '清除活动工作表上单元格A1中的内容'清除选定区域内容Range(“A1:D4”).Clear '彻底清除A1至D4单元格区域的内容,包括格式(35) '清除工作表中所有单元格的内容(36) (1,0).Select '活动单元格下移一行,同理,可下移一列(37) Range(“A1”).Offset(ColumnOffset:=1)或Range(“A1”).Offset(,1) ‘偏移一列Range(“A1”).Offset(Rowoffset:=-1)或Range(“A1”).Offset(-1) ‘向上偏移一行(38) Range(“A1”).Copy Range(“B1”) '复制单元格A1,粘贴到单元格B1中Range(“A1:D8”).Copy Range(“F1”) '将单元格区域复制到单元格F1开始的区域中Range(“A1:D8”).Cut Range(“F1”) '剪切单元格区域A1至D8,复制到单元格F1开始的区域中Range(“A1”). Sheets(“Sheet2”).Range(“A1”) '复制包含A1的单元格区域到工作表2中以A1起始的单元格区域中注:CurrentRegion属性等价于定位命令,由一个矩形单元格块组成,周围是一个或多个空行或列(39) '将值XX输入到所选单元格区域中(40) '活动窗口中选择的单元格数(41) '当前选中区域的单元格数(42) GetAddress=Replace(1).Address,mailto:,””) ‘返回单元格中超级链接的地址并赋值(43) TextColor=Range(“A1”). ‘检查单元格A1的文本颜色并返回颜色索引Range(“A1”). ‘获取单元格A1背景色(44) ‘返回当前工作表的单元格数(45) (“E4”).Select ‘激活当前活动单元格下方3行,向右4列的单元格(46) (5,”C”) ‘引单元格C5(5,3) ‘引单元格C5(47) Range(“A1”).Offset(RowOffset:=4,ColumnOffset:=5)或Range(“A1”).Offset(4,5) ‘指定单元格F5(48) Range(“B3”).Resize(RowSize:=11,ColumnSize:=3)Rnage(“B3”).Resize(11,3) ‘创建B3:D13区域(49) Range(“Data”).Resize(,2) ‘将Data区域扩充2列(50) Union(Range(“Data1”),Range(“Data2”)) ‘将Data1和Data2区域连接(51) Intersect(Range(“Data1”),Range(“Data2”)) ‘返回Data1和Data2区域的交叉区域(52) Range(“Data”).Count ‘单元格区域Data中的单元格数Range(“Data”). ‘单元格区域Data中的列数Range(“Data”). ‘单元格区域Data中的行数(53) ‘当前选中的单元格区域中的列数‘当前选中的单元格区域中的行数(54) ‘选中的单元格区域所包含的区域数(55) ‘获取单元格区域中使用的第一行的行号(56) ‘获取单元格区域Rng左上角单元格所在列编号(57) ‘在活动工作表中返回所有符合条件格式设置的区域(58) Range(“A1”).AutoFilter Field:=3,VisibleDropDown:=False ‘关闭由于执行自动筛选命令产生的第3个字段的下拉列表名称(59) Range(“A1:C3”).Name=“computer” ‘命名A1:C3区域为computer或Range(“D1:E6”).Name=“Sheet1!book” ‘命名局部变量,即Sheet1上区域D1:E6为book或Names(“computer”).Name=“robot” ‘将区域computer重命名为robot(60) Names(“book”).Delete ‘删除名称(61) Name:=“ContentList”,_RefersTo:=“=OFFSET(Sheet1!A2,0,0,COUNTA(Sheet2!$A:$A))” ‘动态命名列(62) Name:=“Company”,RefersTo:=“CompanyCar” ‘命名字符串CompanyCar(63) Name:=“Total”,RefersTo:=123456 ‘将数字123456命名为Total。
ug二次开发vb.netnx1980写入Excel
ug⼆次开发nx1980写⼊Excel1.写⼊ExcelImports SystemImports NXOpenModule NXJournalSub Main(ByVal args() As String)Dim theSession As NXOpen.Session = NXOpen.Session.GetSession()Dim workPart As NXOpen.Part = theSession.Parts.WorkDim displayPart As NXOpen.Part = theSession.Parts.DisplayDim ExcelFileOpen = theSession.SpreadsheetManager().OpenFile("C:\\t.xlsx", SpreadsheetManager.OpenMode.Write) Dim worksheet = ExcelFileOpen.GetWorksheetIndex("Sheet1")Dim Rows As Integer = 2Dim Cols As Integer = 3Dim CellData(Rows * Cols - 1) As SpreadsheetCellData '要指定类组的长度,对应赋值,不要有空的不然写⼊EXCEL出错。
Dim i As Integer = 0Dim s As Integer = 0For s = 0To Rows - 1'⾏数For i = 0To Cols - 1'列数CellData(i + s * Cols) = theSession.SpreadsheetManager().CreateCellData()CellData(i + s * Cols).Type = SpreadsheetCellData.Types.StringCellData(i + s * Cols).StringValue = "Test" & (i + s * Cols)Next iNext sExcelFileOpen.WriteSpreadsheetRange(worksheet, 1, 1, Rows, Cols, CellData)CellData = NothingExcelFileOpen.CloseFile(True)ExcelFileOpen.Dispose()ExcelFileOpen = NothingMsgBox("写⼊成功")End SubEnd Module2.读ExcelImports SystemImports NXOpenModule NXJournalSub Main(ByVal args() As String)Dim theSession As NXOpen.Session = NXOpen.Session.GetSession()Dim workPart As NXOpen.Part = theSession.Parts.WorkDim displayPart As NXOpen.Part = theSession.Parts.DisplayDim ExcelFileOpen = theSession.SpreadsheetManager().OpenFile("C:\\t.xlsx", SpreadsheetManager.OpenMode.Write) Dim worksheet = ExcelFileOpen.GetWorksheetIndex("Sheet1")Dim CellData As SpreadsheetCellData()' -------------读数据------------------------------------ExcelFileOpen.ReadRange(worksheet, 1, 1, 3, 3, CellData)' ExcelFileOpen.ReadSpreadsheetRange(worksheet, 1, 1, 3, 3, CellData)'读取数据中前5个数据分别是下⾯'worksheet: worksheet ID'rowstart: Starting row of the range'colstart: Starting column of the range'rowend: Ending row of the range'colend: Ending column of the rangeDim i = 0For i = 0To CellData.Length - 1If CellData(i).Type = SpreadsheetCellData.Types.Int ThenMsgBox(CellData(i).IntValue() & " INT " & i & "" & CellData(i).Type)End IfIf CellData(i).Type = SpreadsheetCellData.Types.String ThenMsgBox(CellData(i).StringValue() & " STR " & i & "" & CellData(i).Type)End IfIf CellData(i).Type = SpreadsheetCellData.Types.Logical ThenMsgBox(CellData(i).LogicalValue() & " Logical " & i & "" & CellData(i).Type)End IfIf CellData(i).Type = SpreadsheetCellData.Types.Double ThenMsgBox(CellData(i).DoubleValue() & " Double " & i & "" & CellData(i).Type)End IfIf CellData(i).Type = SpreadsheetCellData.Types.Formula ThenMsgBox(CellData(i).FormulaValue() & " Formula " & i & "" & CellData(i).Type)End IfNext' ExcelFileOpen.SetRangeBackgroundColor(worksheet, 2, 2, 2, 2, {230.0, 98.0, 105.0}) '设置单元格背景⾊ *仅对有值的单元格有效后⾯.0要有'ExcelFileOpen.SetSheetTabBackgroundColor(worksheet, {230.0, 98.0, 105.0}) '设置表栏CellData = NothingExcelFileOpen.CloseFile(True)ExcelFileOpen.Dispose()ExcelFileOpen = NothingMsgBox("读取成功")End SubEnd Module3.⽤在UIstylerPublic Sub OnMenuCallback(ByVal tree As NXOpen.BlockStyler.Tree, ByVal node As NXOpen.BlockStyler.Node, ByVal columnID As Integer)Dim menu = tree.CreateMenu()menu.AddMenuItem(0,"导出电⼦表格")tree.SetMenu(menu)End SubPublic Sub onmenucommandcallback(ByVal tree As NXOpen.BlockStyler.Tree, ByVal node As NXOpen.BlockStyler.Node, ByVal menu_item_id As Integer) If RowNums = 0Then Exit Sub'Dim ExcelFile = theSession.SpreadsheetManager().OpenFile("C:\\t.xlsx", SpreadsheetManager.OpenMode.Write)'Dim worksheet = ExcelFile.GetWorksheetIndex("Sheet1")'Dim root = tree.RootNode()'Dim RowS As Integer = RowNums'Dim Cols = tree.NumberOfColumns'Dim CellData(RowS * Cols - 1) As SpreadsheetCellData '要指定类组的长度,对应赋值,不要有空的不然写⼊EXCEL出错。
ADO技术在Microsoft Office Excel二次开发中的应用
图 2 系 统 主 要 功 能 模 块
年级 、 大学 二 年 级 、 大学 三 年 级 3个 年 级 的 学
以学生 信息 管理 模块 为例 , 据 系统 功能 需 根
生 信息 , 借助 A O技术 , 纯 文 本 S L语 句 直 D 把 Q 接 传 到 数 据 源 中 , 其 进 行 相 关 的 操 作 即 对 可 , 分 代 码 如下 : 部
Fo = 1 To r . ed .Co t ri s Fil s un
“|
,
C l ( , )V le = r Fe si一 1 . a e e s 1 i. a l u s il ( . d )Nm
Ne t x
R ne ”2 ) C p Fo R crst" ag ( a ” . o yrm eode I 8
5 8
要 功能 模块 , 图 2所示 . 如
系部 管理 员对 系部的 擘生信 息进行 增加 、
删 除 、更新
On Er o s me Ne t r r Re u x
c n Op n o n. e
教师信 息管理
在 学 院的学 生评教 系统 中 , 针对 大批 量数 据 的 处 理 也 是 采 用 逐 条 更 新 .因 为 管 理 员 在
与命令对 象有 关的参数
记 录集 中 某 个 字段 的信 息
点, 因此 在学生 评教 系统 的系 部管 理 软件 中采 用
了这 一 技 术 , 据 库 采 用 S L S re 0 0 E cl 数 Q evr 0 . xe 2
2 软 件 系统 功 能 与设 计
根据 系部管 理软 件 的需 求 , 系统 分 为 4个 主
系部 管理 模 块
excel二次开发实例
excel二次开发实例Excel 二次开发是指在Microsoft Excel 应用程序的基础上,通过编程和定制化的方式对其进行扩展和改进。
这通常涉及使用VBA(Visual Basic for Applications)、使用Excel 插件(例如COM 插件)、使用Office 添加程序等。
下面是一个简单的Excel 二次开发实例,使用VBA 进行自动化和定制。
示例:自动计算平均值假设有一个Excel 工作表,包含若干个数字,我们希望通过VBA 编程实现自动计算这些数字的平均值。
1. 打开Excel,按下`Alt + F11` 打开VBA 编辑器。
2. 在VBA 编辑器中,插入一个新的模块。
右键单击“VBAProject(你的工作簿名称)”,选择“插入”-> “模块”。
3. 在新插入的模块中,编写以下VBA 代码:```vbaSub 计算平均值()Dim 数据范围As RangeDim 单元格As RangeDim 总和As DoubleDim 平均值As Double' 定义数据范围,例如A 列的所有数字Set 数据范围= Range("A:A")' 初始化总和总和= 0' 遍历数据范围,计算总和For Each 单元格In 数据范围If IsNumeric(单元格.Value) Then总和= 总和+ 单元格.ValueEnd IfNext 单元格' 计算平均值If 数据范围.Cells.Count > 0 Then平均值= 总和/ 数据范围.Cells.CountElse平均值= 0End If' 在B 列第一行输出平均值Range("B1").Value = "平均值:"Range("B2").Value = 平均值End Sub```4. 关闭VBA 编辑器,返回Excel。
基于VB语言的EXCEL和CST以及AutoCAD与ANSYS等的二次开发
基于VB语言的EXCEL、CST以及HFSS等的二次开发代码1:vb创建xls表,并写入内容Set ExcelApp = CreateObject("Excel.Application") '创建EXCEL对象Set ExcelBook = ExcelApp.Workbooks.AddSet ExcelSheet = ExcelBook.Worksheets(1) '添加工作页ExcelSheet.Activate '激活工作页ExcelApp.DisplayAlerts = False="sheet1"ExcelSheet.Range("A1").Value = 100 '设置A1的值为100ExcelBook.SaveAs "d:\test.xls" '保存工作表msgbox "d:\test.xls创建成功!"ExcelBook.closeset excelApp=nothingset ExcelBook=nothingset ExcelSheet=nothing将以上代码copy到记事本存为"writexls.vbs"文件,可运行测试代码2:读execel文件Set ExcelApp = CreateObject("Excel.Application") '创建EXCEL对象Set ExcelBook = ExcelApp.Workbooks.open("d:\test.xls")Set ExcelSheet = ExcelBook.Worksheets(1)msgbox ExcelSheet.Range("A1").Value将以上代码copy到记事本存为"readxls.vbs"文件,可运行测试代码3:上述代码联合调试Dim ExcelApp,ExcelBook,ExcelSheetSet ExcelApp = CreateObject("Excel.Application") '创建EXCEL对象Set ExcelBook = ExcelApp.Workbooks.AddSet ExcelSheet = ExcelBook.Worksheets(1) '添加工作页ExcelSheet.Activate '激活工作页ExcelApp.DisplayAlerts = False="sheet1"ExcelSheet.Range("A1").Value = 100 '设置A1的值为100ExcelBook.SaveAs "D:\Study\VBS\Book1.xls" '保存工作表msgbox "d:\Book1.xls创建成功!"ExcelBook.closeset excelApp=nothingset ExcelBook=nothingset ExcelSheet=nothing'ExcelApp.WorkBooks.Close'ExcelApp.QuitSet ExcelApp = CreateObject("Excel.Application")ExcelApp.Visible = True'创建EXCEL对象Set ExcelBook = ExcelApp.Workbooks.open("D:\Study\VBS\Book1.xls")Set ExcelSheet = ExcelBook.Worksheets(1)msgbox ExcelSheet.Range("A1").ValueExcelApp.WorkBooks.CloseExcelApp.Quit若对支持VB脚本的软件进行二次开发,上述描述有借鉴意义。
excel的VB二次开发方法
用VB操作excel方法汇总Private Sub Command3_Click()Dim i As LongDim j As LongDim objExl As Excel.Application '声明对象变量Me.MousePointer = 11 '改变鼠标样式Set objExl = New Excel.Application '初始化对象变量objExl.SheetsInNewWorkbook = 1 '将新建的工作薄数量设为1objExl.Workbooks.Add '增加一个工作薄objExl.Sheets(objExl.Sheets.Count).Name = "book1" '修改工作薄名称objExl.Sheets.Add , objExl.Sheets("book1") '增加第二个工作薄在第一个之后objExl.Sheets(objExl.Sheets.Count).Name = "book2"objExl.Sheets.Add , objExl.Sheets("book2") '增加第三个工作薄在第二个之后objExl.Sheets(objExl.Sheets.Count).Name = "book3"objExl.Sheets("book1").Select '选中工作薄<book1>For i = 1 To 50 '循环写入数据For j = 1 To 5If i = 1 ThenobjExl.Selection.NumberFormatLocal = "@" '设置格式为文本objExl.Cells(i, j) = " E " & i & jElseobjExl.Cells(i, j) = i & jEnd IfNextNextobjExl.Rows("1:1").Select '选中第一行objExl.Selection.Font.Bold = True '设为粗体objExl.Selection.Font.Size = 24 '设置字体大小objExl.Cells.EntireColumn.AutoFit '自动调整列宽objExl.ActiveWindow.SplitRow = 1 '拆分第一行objExl.ActiveWindow.SplitColumn = 0 '拆分列objExl.ActiveWindow.FreezePanes = True '固定拆分objExl.ActiveSheet.PageSetup.PrintTitleRows = "$1:$1" '设置打印固定行objExl.ActiveSheet.PageSetup.PrintTitleColumns = "" '打印标题objExl.ActiveSheet.PageSetup.RightFooter = "打印时间: " & _Format(Now, "yyyy年mm月dd日 hh:MM:ss") objExl.ActiveWindow.View = xlPageBreakPreview '设置显示方式objExl.ActiveWindow.Zoom = 100 '设置显示大小'给工作表加密码objExl.ActiveSheet.Protect "123", DrawingObjects:=True, _Contents:=True, Scenarios:=TrueobjExl.Application.IgnoreRemoteRequests = FalseobjExl.Visible = True '使EXCEL可见objExl.Application.WindowState = xlMaximized 'EXCEL的显示方式为最大化objExl.ActiveWindow.WindowState = xlMaximized '工作薄显示方式为最大化objExl.SheetsInNewWorkbook = 3 '将默认新工作薄数量改回3个Me.MousePointer = 0 '修改鼠标Exit SubEnd Sub全面控制 Excel首先创建 Excel 对象,使用ComObj:Dim ExcelID as Excel.ApplicationSet ExcelID as new Excel.Application1) 显示当前窗口:ExcelID.Visible := True;2) 更改 Excel 标题栏:ExcelID.Caption := '应用程序调用 Microsoft Excel';3) 添加新工作簿:ExcelID.WorkBooks.Add;4) 打开已存在的工作簿:ExcelID.WorkBooks.Open( 'C:\Excel\Demo.xls' );5) 设置第2个工作表为活动工作表:ExcelID.WorkSheets[2].Activate;或 ExcelID.WorkSheets[ 'Sheet2' ].Activate;6) 给单元格赋值:ExcelID.Cells[1,4].Value := '第一行第四列';7) 设置指定列的宽度(单位:字符个数),以第一列为例:ExcelID.ActiveSheet.Columns[1].ColumnsWidth := 5;8) 设置指定行的高度(单位:磅)(1磅=0.035厘米),以第二行为例:ExcelID.ActiveSheet.Rows[2].RowHeight := 1/0.035; // 1厘米9) 在第8行之前插入分页符:ExcelID.WorkSheets[1].Rows[8].PageBreak := 1;10) 在第8列之前删除分页符:ExcelID.ActiveSheet.Columns[4].PageBreak := 0;11) 指定边框线宽度:ExcelID.ActiveSheet.Range[ 'B3:D4' ].Borders[2].Weight := 3;1-左 2-右 3-顶 4-底 5-斜( \ ) 6-斜( / )12) 清除第一行第四列单元格公式:ExcelID.ActiveSheet.Cells[1,4].ClearContents;13) 设置第一行字体属性:ExcelID.ActiveSheet.Rows[1] := '隶书';ExcelID.ActiveSheet.Rows[1].Font.Color := clBlue;ExcelID.ActiveSheet.Rows[1].Font.Bold := True;ExcelID.ActiveSheet.Rows[1].Font.UnderLine := True;14) 进行页面设置:a.页眉:ExcelID.ActiveSheet.PageSetup.CenterHeader := '报表演示';b.页脚:ExcelID.ActiveSheet.PageSetup.CenterFooter := '第&P页';c.页眉到顶端边距2cm:ExcelID.ActiveSheet.PageSetup.HeaderMargin := 2/0.035;d.页脚到底端边距3cm:ExcelID.ActiveSheet.PageSetup.HeaderMargin := 3/0.035;e.顶边距2cm:ExcelID.ActiveSheet.PageSetup.TopMargin := 2/0.035;f.底边距2cm:ExcelID.ActiveSheet.PageSetup.BottomMargin := 2/0.035;g.左边距2cm:ExcelID.ActiveSheet.PageSetup.LeftMargin := 2/0.035;h.右边距2cm:ExcelID.ActiveSheet.PageSetup.RightMargin := 2/0.035;i.页面水平居中:ExcelID.ActiveSheet.PageSetup.CenterHorizontally := 2/0.035; j.页面垂直居中:ExcelID.ActiveSheet.PageSetup.CenterVertically := 2/0.035; k.打印单元格网线:ExcelID.ActiveSheet.PageSetup.PrintGridLines := True;15) 拷贝操作:a.拷贝整个工作表:ed.Range.Copy;b.拷贝指定区域:ExcelID.ActiveSheet.Range[ 'A1:E2' ].Copy;c.从A1位置开始粘贴:ExcelID.ActiveSheet.Range.[ 'A1' ].PasteSpecial;d.从文件尾部开始粘贴:ExcelID.ActiveSheet.Range.PasteSpecial;16) 插入一行或一列:a. ExcelID.ActiveSheet.Rows[2].Insert;b. ExcelID.ActiveSheet.Columns[1].Insert;17) 删除一行或一列:a. ExcelID.ActiveSheet.Rows[2].Delete;b. ExcelID.ActiveSheet.Columns[1].Delete;18) 打印预览工作表:ExcelID.ActiveSheet.PrintPreview;19) 打印输出工作表:ExcelID.ActiveSheet.PrintOut;20) 工作表保存:If not ExcelID.ActiveWorkBook.Saved thenExcelID.ActiveSheet.PrintPreviewEnd if21) 工作表另存为:ExcelID.ActiveWorkbook.SaveAs FileName:="C:\Excel\Demo1.xls"22) 放弃存盘:ExcelID.ActiveWorkBook.Saved := True;23) 关闭工作簿:ExcelID.WorkBooks.Close;24) 退出 Excel:ExcelID.Quit;25) 设置工作表密码:ExcelID.ActiveSheet.Protect "123", DrawingObjects:=True, Contents:=True, Scenarios:=True26) EXCEL的显示方式为最大化ExcelID.Application.WindowState = xlMaximized27) 工作薄显示方式为最大化ExcelID.ActiveWindow.WindowState = xlMaximized28) 设置打开默认工作薄数量ExcelID.SheetsInNewWorkbook = 329) '关闭时是否提示保存(true 保存;false 不保存)ExcelID.DisplayAlerts = False30) 设置拆分窗口,及固定行位置ExcelID.ActiveWindow.SplitRow = 1ExcelID.ActiveWindow.FreezePanes = True31) 设置打印时固定打印内容ExcelID.ActiveSheet.PageSetup.PrintTitleRows = "$1:$1"32) 设置打印标题ExcelID.ActiveSheet.PageSetup.PrintTitleColumns = ""33) 设置显示方式(分页方式显示)ExcelID.ActiveWindow.View = xlPageBreakPreview34) 设置显示比例ExcelID.ActiveWindow.Zoom = 100Excel 语句集300定制模块行为(1) Option Explicit '强制对模块内所有变量进行声明Option Private Module '标记模块为私有,仅对同一工程中其它模块有用,在宏对话框中不显示Option Compare Text '字符串不区分大小写Option Base 1 '指定数组的第一个下标为1(2) On Error Resume Next '忽略错误继续执行VBA代码,避免出现错误消息(3) On Error GoTo ErrorHandler '当错误发生时跳转到过程中的某个位置(4) On Error GoTo 0 '恢复正常的错误提示(5) Application.DisplayAlerts=False '在程序执行过程中使出现的警告框不显示(6) Application.ScreenUpdating=False '关闭屏幕刷新Application.ScreenUpdating=True '打开屏幕刷新(7) Application.Enable.CancelKey=xlDisabled '禁用Ctrl+Break中止宏运行的功能工作簿(8) Workbooks.Add() '创建一个新的工作簿(10) ThisWorkbook.Save '保存工作簿(11) ThisWorkbook.close '关闭当前工作簿(12) ActiveWorkbook.Sheets.Count '获取活动工作薄中工作表数(13) '返回活动工作薄的名称(14) ‘返回当前工作簿名称ThisWorkbook.FullName ‘返回当前工作簿路径和名称(15) ActiveWindow.EnableResize=False ‘禁止调整活动工作簿的大小(16) Applicatio n.Window.Arrange xlArrangeStyleTiled ‘将工作簿以平铺方式排列(17) ActiveWorkbook.WindowState=xlMaximized ‘将当前工作簿最大化工作表(18) edRange.Rows.Count ‘当前工作表中已使用的行数(19) Rows.Count ‘获取工作表的行数(注:考虑向前兼容性)(20) Sheets(Sheet1).Name= “Sum” '将Sheet1命名为Sum(21) ThisWorkbook.Sheets.Add Before:=Worksheets(1) '添加一个新工作表在第一工作表前(22) ActiveSheet.Move After:=ActiveWorkbook. _Sheets(ActiveWorkbook.Sheets.Count) '将当前工作表移至工作表的最后(23) Worksheets(Array(“sheet1”,”sheet2”)).Select '同时选择工作表1和工作表2(24) Sheets(“sheet1”).Delete或 Sheets(1).Delete '删除工作表1(25) ActiveWorkbook.Sheets(i).Name '获取工作表i的名称(26) ActiveWindow.DisplayGridlines=Not ActiveWindow.DisplayGridlines '切换工作表中的网格线显示,这种方法也可以用在其它方面进行相互切换,即相当于开关按钮(27) ActiveWindow.DisplayHeadings=Not ActiveWindow.DisplayHeadings ‘切换工作表中的行列边框显示(28) edRange.FormatConditions.Delete ‘删除当前工作表中所有的条件格式(29) Cells.Hyperlinks.Delete ‘取消当前工作表所有超链接(30) ActiveSheet.PageSetup.Orientation=xlLandscape或ActiveSheet.PageSetup.Orientation=2 '将页面设置更改为横向(31) ActiveSheet.PageSetup.RightFooter=A ctiveWorkbook.FullName ‘在页面设置的表尾中输入文件路径ActiveSheet.PageSetup.LeftFooter=erName ‘将用户名放置在活动工作表的页脚单元格/单元格区域(32) ActiveCell.CurrentRegion.Select或Range(ActiveCell.End(xlUp),ActiveCell.End(xlDown)).Select'选择当前活动单元格所包含的范围,上下左右无空行(33) Cells.Select ‘选定当前工作表的所有单元格(34) Range(“A1”).ClearContents '清除活动工作表上单元格A1中的内容Selection.ClearContents '清除选定区域内容Range(“A1:D4”).Clear '彻底清除A1至D4单元格区域的内容,包括格式(35) Cells.Clear '清除工作表中所有单元格的内容(36) ActiveCell.Offset(1,0).Select '活动单元格下移一行,同理,可下移一列(37) Range(“A1”).Offset(ColumnOffset:=1)或Range(“A1”).Offset(,1) ‘偏移一列Range(“A1”).Offset(Rowoffset:=-1)或Range(“A1”).Offset(-1) ‘向上偏移一行(38) Range(“A1”).Copy Range(“B1”) '复制单元格A1,粘贴到单元格B1中Range(“A1:D8”).Copy Range(“F1”) '将单元格区域复制到单元格F1开始的区域中Range(“A1:D8”).Cut Range(“F1”) '剪切单元格区域A1至D8,复制到单元格F1开始的区域中Range(“A1”).CurrentRegion.Copy Sheets(“Sheet2”).Range(“A1”) '复制包含A1的单元格区域到工作表2中以A1起始的单元格区域中注:CurrentRegion属性等价于定位命令,由一个矩形单元格块组成,周围是一个或多个空行或列(40) ActiveWindow.RangeSelection.Count '活动窗口中选择的单元格数(41) Selection.Count '当前选中区域的单元格数(42) GetAddress=Replace(Hyperlinkcell.Hyperlinks(1).Address,mailto:,””) ‘返回单元格中超级链接的地址并赋值(43) TextColor=Range(“A1”).Font.ColorIndex ‘检查单元格A1的文本颜色并返回颜色索引Range(“A1”).Interior.ColorIndex ‘获取单元格A1背景色(44) cells.count ‘返回当前工作表的单元格数(45) Selection.Range(“E4”).Select ‘激活当前活动单元格下方3行,向右4列的单元格(46) Cells.Item(5,”C”) ‘引单元格C5Cells.Item(5,3) ‘引单元格C5(47) Range(“A1”).Offset(RowOffset:=4,ColumnOffset:=5)或Range(“A1”).Offset(4,5) ‘指定单元格F5(48) Range(“B3”).R esize(RowSize:=11,ColumnSize:=3)Rnage(“B3”).Resize(11,3) ‘创建B3:D13区域(49) Range(“Data”).Resize(,2) ‘将Data区域扩充2列(50) Union(Range(“Data1”),Range(“Data2”)) ‘将Data1和Data2区域连接(51) Intersect(Range(“Data1”),Range(“Data2”)) ‘返回Data1和Data2区域的交叉区域(52) Range(“Data”).Count ‘单元格区域Data中的单元格数Range(“Data”). Columns.Count ‘单元格区域Data中的列数Range(“Data”). Rows.Count ‘单元格区域Data中的行数(53) Selection.Columns.Count ‘当前选中的单元格区域中的列数Selection.Rows.Count ‘当前选中的单元格区域中的行数(54) Selection.Areas.Count ‘选中的单元格区域所包含的区域数(55) ActiveShe edRange.Row ‘获取单元格区域中使用的第一行的行号(56) Rng.Column ‘获取单元格区域Rng左上角单元格所在列编号(57) ActiveSheet.Cells.SpecialCells(xlCellTypeAllFormatConditions) ‘在活动工作表中返回所有符合条件格式设置的区域(58) Range(“A1”).AutoFilter Field:=3,VisibleDropDown:=False ‘关闭由于执行自动筛选命令产生的第3个字段的下拉列表名称(59) Range(“A1:C3”).Name=“computer” ‘命名A1:C3区域为computer或Range(“D1:E6”).Name=“Sheet1!book” ‘命名局部变量,即Sheet1上区域D1:E6为book或Names(“computer”).Name=“robot” ‘将区域computer重命名为robot(60) Names(“book”).Delete ‘删除名称(61) Names.Add Name:=“ContentList”,_RefersTo:=“=OFFSET(Sheet1!A2,0,0,COUNTA(Sheet2!$A:$A))” ‘动态命名列(62) Names.Add Name:=“Company”,RefersTo:=“CompanyCar” ‘命名字符串CompanyCar(63) Names.Add Name:=“Total”,RefersTo:=123456 ‘将数字123456命名为Total。
wps二次开发案例
WPS二次开发案例一、介绍WPS Office是一款功能强大的办公软件套件,包括文字处理、表格计算和演示文稿等功能。
WPS二次开发是指在WPS Office的基础上进行二次开发,根据自己的需求进行定制和扩展,以满足个性化的办公需求。
本文将通过案例分析,深入探讨WPS二次开发的具体应用。
二、案例一:自动化生成报告2.1 需求分析某公司每月需要生成大量的报告,包括销售报告、财务报告等。
传统的生成方式是手动填写模板,耗时且容易出错。
因此,需要开发一个自动化的报告生成工具,能够根据输入的数据自动生成报告。
2.2 解决方案1.使用WPS二次开发工具,通过调用WPS Office的API实现自动化生成报告的功能。
2.开发一个报告生成程序,通过读取数据库或Excel表格中的数据,将数据填充到报告模板中。
3.使用WPS Office的模板功能,设计好报告的样式和格式,并保存为模板文件。
4.程序在生成报告时,先根据模板文件创建一个新的文档,然后将数据填充到文档中,并保存为最终的报告文件。
2.3 实施步骤1.创建一个WPS Office的文档对象。
2.打开报告模板文件,并将其作为基础文档。
3.读取数据库或Excel表格中的数据。
4.根据数据的内容,使用WPS Office提供的API将数据填充到文档中的相应位置。
5.保存生成的报告文件。
2.4 效果与总结通过WPS二次开发,成功实现了自动化生成报告的功能,大大提高了工作效率。
只需输入数据,程序就能自动生成报告,减少了手工操作的时间和错误。
同时,使用WPS Office的模板功能,使得报告的样式和格式统一,提高了报告的质量和专业性。
三、案例二:批量处理文档3.1 需求分析某公司需要对大量的文档进行批量处理,包括转换格式、合并文档等操作。
传统的处理方式需要逐个打开文档并进行操作,耗时且效率低下。
因此,需要开发一个批量处理文档的工具,能够自动完成这些操作。
3.2 解决方案1.使用WPS二次开发工具,通过调用WPS Office的API实现批量处理文档的功能。
excel二次开发教程
目录一、VBA语言基础 (1)第一节标识符 (1)第二节运算符 (1)第三节数据类型 (1)第四节变量与常量 (1)第五节数组 (2)第六节注释和赋值语句 (2)第七节书写规范 (2)第八节判断语句 (2)第九节循环语句 (3)第十节其他类语句和错误语句处理 (4)第十一节过程和函数 (4)一.Sub过程 (4)二.Function函数 (5)三.Property属性过程和Event事件过程 (5)第十二节内部函数 (5)一.测试函数 (5)二.数学函数 (5)三.字符串函数 (5)四.转换函数 (6)五.时间函数 (6)第十三节文件操作 (6)文件 (6)删除 (6)打开 (6)读入 (7)写入 (7)关闭 (7)其他文件函数 (7)二、VISUALBASIC程序设计网络教学 (1)第一课VBA是什么 (1)1.1VBA是什么 (1)1.2EXCEL环境中基于应用程序自动化的优点 (1)1.3录制简单的宏 (1)1.4执行宏 (2)1.5查看录制的代码 (2)1.6编辑录制的代码 (3)1.7录制宏的局限性..........................................................................................................................31.8小结 (3)第二课处理录制的宏 (3)2.1为宏指定快捷键 (3)2.2决定宏保存的位置 (4)2.3个人宏工作簿 (4)2.3.1保存宏到个人宏工作簿 (4)2.3.2使用并编辑个人宏工作簿中的宏. (4)2.4将宏指定给按钮 (4)2.5将宏指定给图片或其他对象 (5)2.6小结 (5)第三课学习控件 (5)3.1EXCEL开发过程简介 (5)3.2认识不同的控件 (5)3.3向工作表添加控件 (6)3.4设置控件的特性 (6)3.5给控件命名 (6)3.6使用用户窗体 (6)3.7疑难解答 (7)第四课理解变量和变量的作用 (7)4.1代码存在的位置:模块 (7)4.2对模块的概览 (7)4.2.1创建过程 (8)4.2.2运行宏 (9)4.3保存对模块所做的改变 (9)4.4变量 (9)4.4.1变量的数据类型 (9)4.4.2用Dim语句创建变量(声明变量) (10)4.4.3变量命名的惯例 (10)4.4.4使用数组 (10)4.4.5变量赋值 (11)第五课利用VBA设置工作表使用权限 (11)1.使用WITH语句。
PYTHON连接EXCEL ABAUQUS 二次开发
1.import xlrd2.data=xlrd.open_workbook('D:\\abaqus\\model.xls')3.sh=data.sheet_by_name('summary')4.print sh.c ell_value(1,1)5.print sh.c ell_value(1,2)6.print sh.c ell_value(2,1)复制代码运行前更改上面的目录'D:\\abaqus\\model.xls'为你本机model.xls的目录。
可以看到输出:10.060.0100.0>>>这说明你的python和xlrd都安装没有问题的。
从上面的小程序可以看出必须将xlrd import到程序中才能使用,就像我们在abaqus python脚本中常见的一样1.from abaqus import*2.from abaqusConstants import*3.from c aeModules import*复制代码但是如果偶们在abaqus中写python脚本建模时要用到ex c el中的模型相关数据,必然也会想到import这两个包但是这时候就会发现,系统找不到这两个包。
[atta c h]287781[/atta c h]原因在于abaqus解释编译python脚本时候用的是自己的带的python,而不是我们装的那个。
所以就需要我们把那两个包安装的文件手动导入到abaqus自带的python目录下。
下面以xlrd(读取ex c el的包)为例来讲讲怎么实现在abaqus中使用python连接ex c el。
(那个xlrt是用python写入数据到ex c el文件里面用的)首先,找到你xlrd安装的目录,比如我的就在C:\Python27下面。
你应该可以发现一个叫做xlrd-wininst.log 的安装日志文件,打开内容差不多如下:***Installation started2011/04/0921:17***Sour c e:D:\Ba c kup\我的文档\下载\xlrd-0.7.1.win32.exe999Root Key:HKEY_LOCAL_MACHINE020Reg DB Key:[Software\Mi c rosoft\Windows\CurrentVersion\Uninstall]xlrd-py2.7040Reg DB Value:[Software\Mi c rosoft\Windows\CurrentVersion\Uninstall\xlrd-py2.7]DisplayName=Python2.7 xlrd-0.7.1040Reg DB Value: [Software\Mi c rosoft\Windows\CurrentVersion\Uninstall\xlrd-py2.7]UninstallString="C:\Python27\Removexlrd.ex e"-u"C:\Python27\xlrd-wininst.log"200File Copy:C:\Python27\Lib\site-pa c kages\xlrd-0.7.1-py2.5.egg-info100Made Dir:C:\Python27\Lib\site-pa c kages\xlrd200File Copy:C:\Python27\Lib\site-pa c kages\xlrd\biffh.py200File Copy:C:\Python27\Lib\site-pa c kages\xlrd\c ompdo c.py200File Copy:C:\Python27\Lib\site-pa c kages\xlrd\formatting.py200File Copy:C:\Python27\Lib\site-pa c kages\xlrd\formula.py。
基于 ChinaExcel 报表工具二次开发研究
统计脚本是 以 < s t a t >做 为开始 小节 。
已被 更 改, 是 否 保 存? ” , v b E x c l a ma t i o n o r
v b Y e s No Ca n c e 1 )
I f r t n=vb Y e sTh e n mnu Fi l e Sa ve
以 使 用 Ge t S t a t S c r i p t 方 法 来 返 回对 应 的 统 计 脚 本。
可以跨组进行组 合 ,这个值只有 < c o m b i >为 1
的时候 才有 用。
< i f e l d 2 >表 示 从 表 第 2个 字 段 定 义 小 节 。
I f C e l l We b 1 . I s B o o k Mo d i i f e d ( ) T h e n r t n: M s g B o x (” 文 档
’ Ce l l We b 1 . On Bo o k Op e n
C a l l Op e n Mo d e l Au t o ( g u i d )
m e nu
—
< c o mb i >表示 内容相同的单元是否组合 , 如果是 1 则表示要组 合,否 则不 自动组 合。 < c o mb i o n e g r o u p >表示否 则只在 同一组 中 组 合 ,1 表示 是在 同一组 中进行 组合 ,0表示
S o f t wa r e D e v e l o p me n t・ 软件开发
在 您 的 安 装程 序 中运 行 Re g s v r 3 2命 令 注 册 C h i n a E x c e l 组件 。 若 在其 他 系统 中集 成使 用 C h i n a E x c e l 报 表组 件 ,可 以通过 代码实 现 O C X及 d 儿控 件 自 < i f e l d n a me >表示字段名称 。 < r o w>表示字段显示的行号 。 < c o l >表示字段 显示 的列号 。 < i f e l d 2 >表示主表第 2个字段定义小节。 < s u b >小节 中的 < c o u n t >表示从表 字段个
Excel工作表二次开发在模拟水氡日常观测中的应用
参考 文献 :
[] 1王修晖, 华炜等. 面向多投影显示墙的画面校正技术研 究, 软
[】 志强 . n o s编程 技 术[ . : 工 业 出版社 2张 Widw M】 北京 机械 [ 宋坤 , 宁 .i l + 程 序设 计 自学手册 , 日科技 , 0, 3 】 刘锐 Vs + ac 明 2 8 0 2
27 0。
四 、屏 幕分 割模 块 的程序 实 现及 结果
总体 设计
本系 统 只是 多屏 幕绘 制系 统 其 中 的一个模 块 ,其 他模 块还 包
括 时钟 同步 ,通 讯两 个模 块 。 由于是 单独 的 一个 子块 ,他 不 能很
本文 研 究 的是 如何读 取服 务 器屏 幕 分辨 率然 后根 据所 需 分割
京: 震 出版 社 : 1 地 9 1 .
3 置 完成 后需 要对 公式 进行 锁 定 ,防止 误操 作改 变 设置 。 . 设 四 、结 束语
水 氡 浓度 观测 是 我 国 目前 地震 水 文地 球化 学监 测 台 网的主 测 项 目,很 多地 震 台站 都有 该项 目。除 S 3 型 自动 测氡 仪 外 ,所 D.A
有 的 原始观 测 记录 仍 都 由手工 填 写到 纸介 质上 ,计 算 比较 繁琐 、
【] 国地 震局 监 测预 报 司. 9 . 地 下 流 体观 测 技 术 【 . 2中 1 5地震 9 M】
北京 : 出版社 : 311 地震 1 .3 0
容 易 出错 ,且 无法 实现 数 字化 存档 、备 份 ,万 一丢 失 ,将 造成 无
本 系统 屏幕 分割 显 示模块 主 要实 现功 能如 下 :
1 现 22 + . 实 */ 3的屏 幕切 割 。 2 2显 示其 中某 一切 割 后 的图像 。 .
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
目录一、VBA语言基础 (1)第一节标识符 (1)第二节运算符 (1)第三节数据类型 (1)第四节变量与常量 (1)第五节数组 (2)第六节注释和赋值语句 (2)第七节书写规范 (2)第八节判断语句 (2)第九节循环语句 (3)第十节其他类语句和错误语句处理 (4)第十一节过程和函数 (4)一.Sub过程 (4)二.Function函数 (5)三.Property属性过程和Event事件过程 (5)第十二节内部函数 (5)一.测试函数 (5)二.数学函数 (5)三.字符串函数 (5)四.转换函数 (6)五.时间函数 (6)第十三节文件操作 (6)文件 (6)删除 (6)打开 (6)读入 (7)写入 (7)关闭 (7)其他文件函数 (7)二、VISUALBASIC程序设计网络教学 (1)第一课VBA是什么 (1)1.1VBA是什么 (1)1.2EXCEL环境中基于应用程序自动化的优点 (1)1.3录制简单的宏 (1)1.4执行宏 (2)1.5查看录制的代码 (2)1.6编辑录制的代码 (3)1.7录制宏的局限性..........................................................................................................................31.8小结 (3)第二课处理录制的宏 (3)2.1为宏指定快捷键 (3)2.2决定宏保存的位置 (4)2.3个人宏工作簿 (4)2.3.1保存宏到个人宏工作簿 (4)2.3.2使用并编辑个人宏工作簿中的宏. (4)2.4将宏指定给按钮 (4)2.5将宏指定给图片或其他对象 (5)2.6小结 (5)第三课学习控件 (5)3.1EXCEL开发过程简介 (5)3.2认识不同的控件 (5)3.3向工作表添加控件 (6)3.4设置控件的特性 (6)3.5给控件命名 (6)3.6使用用户窗体 (6)3.7疑难解答 (7)第四课理解变量和变量的作用 (7)4.1代码存在的位置:模块 (7)4.2对模块的概览 (7)4.2.1创建过程 (8)4.2.2运行宏 (9)4.3保存对模块所做的改变 (9)4.4变量 (9)4.4.1变量的数据类型 (9)4.4.2用Dim语句创建变量(声明变量) (10)4.4.3变量命名的惯例 (10)4.4.4使用数组 (10)4.4.5变量赋值 (11)第五课利用VBA设置工作表使用权限 (11)1.使用WITH语句。
..........................................................................................2.使用对象变量。
.........................................................................................方法3:减少对象的激活和选择....................................................................方法4:关闭屏幕更新....................................................................................第六课提高EXCEL中VBA的效率 (12)方法1:尽量使用VBA原有的属性、方法和WORKSHEET函数 (12)方法2:尽量减少使用对象引用,尤其在循环中 (12)1.使用With语句。
(12)2.使用对象变量。
(12)3.在循环中要尽量减少对象的访问。
(13)方法3:减少对象的激活和选择 (13)方法4:关闭屏幕更新 (13)第七课如何在EXCEL里使用定时器 (13)三、学习微软EXCEL2002VBA编程和XML,ASP技术 (15)第一章电子表格自动化简介和了解宏命令 (15)1了解宏 (15)2宏命令的普通应用 (15)3写宏之前的计划 (16)4录制宏 (17)5运行宏 (18)6修改宏代码 (19)7添加注释 (21)8分析宏代码 (22)9清除宏代码 (23)10测试修改好的宏 (24)11两个层面运行宏的方法 (24)12完善你的宏代码 (25)13重新命名宏 (27)14运行宏的其它方法 (27)15使用键盘快捷键运行宏 (27)16通过菜单运行宏 (28)17通过工具栏按钮运行宏 (30)18通过工作表里面的按钮运行宏 (31)19保存宏 (32)20打印宏 (32)21保存宏在个人宏工作簿 (32)22打开含有宏的工作簿 (34)23VB编辑窗口 (35)24了解工程浏览窗口 (35)25了解属性窗口 (36)26了解代码窗口 (36)27VB编辑器里的其它窗口 (38)第二章VBA第一步 (39)1了解指令,模块和过程 (39)2VBA工程命名 (39)3模块重命名 (40)4从其它工程调用过程 (41)5了解对象,属性和方法 (42)6学习对象,属性和方法 (43)7句法和文法 (45)8打断很长的VBA语句 (47)9了解VBA错误 (47)10查找帮助 (49)11语法和编程快捷助手 (50)12属性/方法列表 (51)13常数列表 (51)14参数信息 (52)15快速信息 (52)16自动完成关键字 (52)17缩进/凸出 (53)18设置注释块/解除注释块 (53)19使用对象浏览器 (53)20使用VBA对象库 (58)21用对象浏览器来定位过程 (59)22使用立即窗口 (59)23获取立即窗口里的信息 (61)24学习对象 (62)25电子表格单元格操作 (62)26使用RANGE属性 (62)27使用CELLS属性 (62)29选择单元格的其它方法 (64)30选择行和列 (64)31获取工作表信息 (65)32往工作表输入数据 (65)33返回工作表中的信息 (65)34单元格格式 (66)35移动,复制和删除单元格 (66)36操作工作簿和工作表 (67)37操作窗口(WINDOWS) (67)38管理EXCEL应用程序 (68)39接下来 (68)第三章了解变量,数据类型和常量 (69)1保存VBA语句的结果 (69)2变量是什么 (69)3数据类型 (69)4如何产生变量 (70)5如何声明变量 (71)6明确变量的数据类型 (72)7变量赋值 (73)8强制声明变量 (75)9了解变量范围 (76)10过程级别(当地)变量 (76)11模块级别变量 (77)12工程级别变量 (77)13变量的存活期 (78)14了解和使用静态变量 (78)15声明和使用对象变量 (79)17查找变量定义 (80)18在VB过程里面使用常量 (80)19内置常量 (81)20接下来 (82)第四章VBA过程:子程序和函数 (82)1.关于函数过程 (82)2.创建函数过程 (82)3.执行函数过程 (84)4.从工作表里运行函数过程 (84)5.从另外一个VBA过程里运行函数过程 (85)6.传递参数 (86)7.明确参数类型 (87)8.按地址和按值传递参数 (88)9.使用可选的参数 (88)10.定位内置函数 (89)11.使用MSGBOX函数 (90)12.MSGBOX函数的运行值 (94)13.使用INPUTBOX函数 (95)14.数据类型转变 (96)15.使用INPUTBOX方法 (97)16.使用主过程和子过程 (100)17.接下来 (102)第五章基于VBA做决定 (102)1.关系和逻辑运算符 (102)2.IF...THEN语句. (103)3.基于多于一个条件的决定 (105)5.IF...THEN...ELSEIF语句. (108)6.嵌套的IF...THEN语句. (110)7.SELECTCASE语句 (110)8.和CASE子句一起使用IS (112)9.确定CASE子句里数值的范围 (113)10.在CASE子句里确定多个表达式 (114)11.接下来 (114)第六章在VBA中重复操作 (114)1.DOLOOPS:DO...WHILE和DO...UNTIL (114)2.观察过程执行 (117)3.WHILE...WEND循环.. (118)4.FOR...NEXT循环 (119)5.FOREACH...NEXT循环 (120)7.提前跳出循环 (121)8.循环嵌套 (122)9.接下来 (122)第七章利用VBA数组管理数据清单和表格 (122)1.了解数组 (123)2.声明数组 (124)3.数组的上界和下界 (124)4.在VBA过程里使用数组 (124)5.数组和循环语句 (125)6.使用二维数组 (127)7.静态和动态数组 (128)8.数组函数 (129)9.ARRAY函数 (130)10.ISARRAY函数 (130)12.LBOUND函数和UBOUND函数 (131)13.数组中的错误 (132)14.数组作为参数 (134)15.接下来 (134)第八章利用VBA操纵文件和文件夹 (134)1.获取当前文件夹的名称(CURDIR函数) (135)2.更改文件或文件夹名称(NAME函数) (135)3.检查文件或文件夹是否存在(DIR函数) (136)4.获得文件修改的日期和时间(FILEDATETIME函数) (137)5.获得文件大小(FILELEN函数) (138)6.返回和设置文件属性(GETATTR函数和SETATTR函数) (138)7.更改缺省文件夹或驱动器(CHDIR语句和CHDRIVE语句) (139)8.创建和删除文件夹(MKDIR语句和RMDIR语句) (140)9.复制文件(FILECOPY语句) (140)10.删除文件(KILL语句) (142)11.从文件读取和写入数据(INPUT/OUTPUT) (142)12.文件访问类型 (142)13.使用顺序文件 (143)14.读取储存于顺序文件里的数据 (143)15.逐行读取文件 (143)16.从顺序文件中读取字符 (144)17.读取分隔文本文件 (145)18.往顺序文件里写数据 (146)19.使用WRITE#和PRINT#语句 (147)20.操作随机文件 (148)21.创建用户定义的数据类型 (148)22.操作二进制文件 (152)23.操作文件和文件夹的时髦方法 (153)25.FILESYSTEMOBJEC的方法和属性 (156)26.对象FILE的属性 (160)27.文件夹对象属性 (161)28.驱动器对象属性 (161)29.使用WSH创建文本文件 (162)30.使用WSH进行其它操作 (164)31.运行其它应用程序 (164)32.创建快捷方式 (165)33.接下来 (166)第九章利用VBA控制其它应用程序 (167)1.启动应用程序 (167)2.在应用程序之间切换 (169)3.控制其它应用程序 (170)4.控制应用程序的其它方法 (171)5.了解自动控制 (172)6.了解链接和嵌入 (172)7.使用VBA进行链接和嵌入 (173)和自动控制 (174)9.了解绑定 (174)10.后期绑定 (174)11.早期绑定 (174)12.建立到对象库的引用 (175)13.创建自动控制对象 (176)14.使用CREATEOBJECT函数 (176)15.使用自动控制创建一个新的WORD文档 (177)16.使用GETOBJECT函数 (177)17.打开存在的WORD文档 (178)19.使用自动控制访问MICROSOFTOUTLOOK (180)20.接下来 (181)第十章对话框和自定义窗体 (181)1.文件打开和另存为对话框 (183)2.GETOPENFILENAME和GETSAVEASFILENAME方法 (187)3.创建窗体 (188)4.创建用户窗体的工具 (190)5.标签 (191)6.文字框 (191)7.框架 (191)8.选项按钮 (191)9.复选框 (192)10.切换按钮 (192)11.列表框 (192)12.复合框 (192)13.滚动条 (192)14.旋转按钮 (192)15.图像 (192)16.多页控件 (192)17.TABSTRIP控件 (193)18.REFEDIT控件 (193)19.在窗体上放置控件 (193)20.应用程序示例1:信息调查 (193)21.在窗体上添加按钮、选项框和其它控件 (194)22.更改控件名称 (197)23.设置其它控件属性 (197)24.准备工作表以储存窗体数据 (198)26.设置TAB顺序 (199)27.了解窗体和控件事件 (200)28.编写VBA过程对窗体和控件事件反应 (201)29.编写过程来初始化窗体 (201)30.编写过程填充列表框控件 (203)31.编写过程控制选项按钮 (203)32.编写过程同步文字框和旋转按钮 (204)33.编写过程关闭用户窗体 (204)34.转移窗体数据到工作表 (205)35.使用INFOSURVEY应用程序 (206)36.应用程序示例2:学生和考试 (206)37.使用多页和TABSTRIP控件 (206)38.给窗体STUDENTSANDEXAMS自定义窗体编写VBA过程 (208)39.使用自定义窗体STUDENTSANDEXAMS (212)40.接下来 (214)第十一章自定义集合和类模块 (214)1.使用集合 (214)2.声明自定义集合 (215)3.给自定义集合添加对象 (215)4.从自定义集合移出对象 (216)5.创建自定义对象 (217)6.创建类 (218)7.变量声明 (218)8.定义类的属性 (218)9.创建PROPERTYGET过程 (219)10.创建PROPERTYLET过程 (219)11.创建类方法 (220)13.类模块里的事件过程 (221)14.创建用户界面 (221)15.观察VBA过程的执行 (229)16.接下来 (231)第十二章使用VBA创建自定义菜单和工具栏 (231)1.工具栏 (232)2.创建自定义工具栏 (233)3.删除自定义工具栏 (235)4.使用COMMANDBAR的属性 (235)5.使用COMMANDBAR控件 (235)6.理解和使用控件属性 (237)7.控件方法 (239)8.使用菜单 (240)9.菜单编程 (241)10.创建子菜单 (243)11.修改内置快捷菜单 (244)12.创建快捷菜单 (247)13.接下来 (249)第十三章调试VBA过程和处理错误 (249)1.测试VBA过程 (249)2.终止过程 (249)3.使用断点 (250)4.在中断模式下使用立即窗口 (253)5.使用STOP语句 (254)6.添加监视表达式 (254)7.清除监视表达式 (256)9.使用本地窗口和调用堆栈对话框 (257)10.逐句运行VBA过程 (258)11.逐句运行过程 (259)12.逐过程执行过程 (259)13.设置下一条语句 (260)14.显示下一条语句 (260)15.终止和重新设置VBA过程 (260)16.了解和使用条件编译 (260)17.操纵书签 (262)18.捕捉错误 (262)17.接下来 (266)第十四章微软EXCEL2002中的事件编程 (266)1.事件过程介绍 (266)2.激活和失活事件 (267)3.事件次序 (268)4.工作表事件 (268)5.工作簿事件 (272)6.图表事件 (282)7.内嵌图表事件 (284)8.可为应用软件对象识别的事件 (285)9.查询表时间 (288)10.接下来 (289)第十五章在EXCEL里使用ACCESS (289)1.对象库 (289)2.建立对对象库的引用 (292)4.使用AUTOMATION链接到ACCESS数据库 (293)5.使用DAO链接到ACCESS数据库 (295)6.使用ADO链接到ACCESS数据库 (295)7.从EXCEL执行ACCESS任务 (296)8.创建新ACCESS数据库 (296)9.打开ACCESS窗体 (298)10.打开ACCESS报表 (300)11.运行ACCESS查询 (301)12.运行选择查询 (302)13.运行参数查询 (303)14.调用ACCESS函数 (304)15.获取ACCESS数据到EXCEL工作表 (304)16.使用GETROWS方法获取数据 (304)17.使用COPYFROMRECORDSET方法获取数据 (305)18.使用TRANSFERSPREADSHEET方法获取数据 (306)19.使用OPENDATABASE方法 (307)20.从ACCESS数据创建文本文件 (309)21.从ACCESS数据创建查询表 (310)22.在EXCEL里使用ACCESS数据 (311)23.用ACCESS数据创建内嵌图表 (311)24.传输EXCEL电子表格到ACCESS数据库 (313)25.将EXCEL电子表格链接到ACCESS数据库 (313)26.将EXCEL电子表格导入ACCESS数据库 (314)27.放置EXCEL数据到ACCESS表中 (314)28.接下来 (316)VBA语言基础橄榄树整理一、VBA语言基础第一节标识符一.定义标识符是一种标识变量、常量、过程、函数、类等语言构成单位的符号,利用它可以完成对变量、常量、过程、函数、类等的引用。