VFP全面控制EXCEL

VFP和Excel都可以用来进行处理数据库表格,如果巧妙地将二者的优点结合起来,将会大大方便我们的工作。比如我们可以利用VFP进 行处理数据,而利用Excel的预览打印功能进行报表打印。这就需要我们在VFP中直接来控制Excel。下面就在开发VFP应用项目时对Excel 的控制作一下介绍:   1.创建Excel对象   eole=CREATEOBJECT(′Excel.application′)   2.添加新工作簿   eole.Workbooks.add   3.设置第3个工作表为激活工作表   eole.Worksheets(″sheet3″).Activate   4.打开指定工作簿   eole.Workbooks.Open(″c:/temp/ll.xls″)   5.显示Excel窗口   eole.visible=.t.   6.更改Excel标题栏   eole.Caption=″VFP应用程序调用Microsoft Excel″   7.给单元格赋值   eole.cells(1,4).value=XM(XM为数据库字段名)   8.设置指定列的宽度(单位:字符个数)   eole.ActiveSheet.Columns(1).ColumnWidth=5   9.设置指定行的高度(单位:磅)   eole.ActiveSheet.Rows(1).RowHeight=1/0.035   (设定行高为1厘米,1磅=0.035厘米)   10.在第18行之前插入分页符   eole.Worksheets(″Sheet1″).Rows(18).PageBreak=1   11.在第4列之前删除分页符   eole.ActiveSheet.Columns(4).PageBreak=0   12.指定边框线宽度(Borders参数如下)   ole.ActiveSheet.Range(″b3:d3″).Borders(2).Weight=3   13.设置四个边框线条的类型   eole.ActiveSheet.Range(″b3:d3″).Borders(2).LineStyle=1   (其中Borders参数:1-左、2-右、3-顶、4-底、5-斜、6-斜/;LineStyle值:1与7-细实、2-细虚、4-点虚、9-双细实线)   14.设置页眉   eole.ActiveSheet.PageSetup.CenterHeader=″报表1″   15.设置页脚   eole.ActiveSheet.PageSetup.CenterFooter=″第&P页″   16.设置页眉到顶端边距为2厘米   eole.ActiveSheet.PageSetup.HeaderMargin=2/0.035   17.设置页脚到底边距为3厘米   eole.ActiveSheet.PageSetup.FooterMargin=3/0.035   18.设置顶边距为2厘米   eole.ActiveSheet.PageSetup.TopMargin=2/0.035   19.设置底边距为4厘米   eole.ActiveSheet.PageSetup.BottomMargin=4/0.035   20.设置左边距为2厘米   veole.ActiveSheet.PageSetup.LeftMargin=2/0.035   21.设置右边距为2厘米   eole.ActiveSheet.PageSetup.RightMargin=2/0.035   22.设置页面水平居中   eole.ActiveSheet.PageSetup.CenterHorizontally=.t.   23.设置页面垂直居中   eole.ActiveSheet.PageSetup.CenterVertically=.t.   24.设置页面纸张大小(1-窄行8511 39-宽行1411)   eole.ActiveSheet.PageSetup.PaperSize=1   25.打印单元格网线   eole.ActiveSheet.PageSetup.PrintGridlines=.t.   26.拷贝整个工作表   eole.ActiveSheet.UsedRange.Copy   27.拷贝指定区域   eole.ActiveSheet.Range(″A1:E2″).Copy   28.粘贴   eole.WorkSheet(″Sheet2″).Range(″A1″).PasteSpecial   29.在第2行之前插入一行   eole.ActiveSheet.Rows(2).Insert   30.在第2列之前插入一列   eole.ActiveSheet.Columns(2).Insert   31.设置字体   eole.ActiveSheet.Cells(2,1).Font.Name=″黑体″   32.设置字体大小   eole.ActiveSheet.Cells(1,1).Font.Size=25   33.设置字体为斜体   eole.ActiveSheet.Cells(1,1).Font.Italic=.t.   34.设置整列字体为粗体   eole.ActiveSheet.Columns(1).Font.Bold=.t.   35.清除单元格公式   eole.ActiveSheet.Cells(1,4).ClearContents   36.打印预览工作表   eole.ActiveSheet.PrintPreview   37.打印输出工作表   eole.ActiveSheet.PrintOut   38.工作表另为   eole.ActiveWorkbook.SaveAs(″c:/temp/22.xls″)   39.放弃存盘   eole.ActiveWorkbook.saved=.t.   40.关闭工作簿   eole.Workbooks.close   41.退出Excel
使用VFP读取EXCEL中的数据示例 *!* *****数据导入程序,由“学生基本基本情况表模板.xls”导入数据 *!* ***使用VFP控制EXCEL表,计取中指定列的内容*********** *!* "学生基本基本情况表模板.xls"的数据布局 *!* cells(1,1):“标题” *!* cells(2,1):校区 *!* cells(2,3):学历 *!* cells(2,5):专业 *!* cells(2,6):班级 *!* *!* set safe off set talk on LOCAL inf(4) as String *dele file C:\MyDocu~1\Resume.xlw objExcel = CreateObject("Excel.Application") &&创建一个EXCEL应用程序实例 wjm=getfile("xls") objExcel.Workbooks.Open(wjm) &&调用workbooks(Microsoft Excel 应用程序; 中当前打开的所有 Workbook 对象的集合。); 对象的open方法程序来打开指定的文件,并为; 打开的文件创建一个新的工作簿 *objexcel.visible=.f. ***下面的代码判断出生日期字段的格式是否满足要求*** *IF !varTYPE(objexcel.cells(10,6))="d" * MESSAGEBOX("出生日期字段不满足格式要求,不能导入,请将出生日期字段修改为:"+CHR(13); +"mm.dd.yy的格式,如:05.19.83 表示1983年5月19 然后再运行此导入程序") * RETURN *ENDIF inf(1)=substr(objexcel.cells(2,1).value,7)&&校区 Inf(2)=objexcel.cells(2,4).value&&学历 inf(3)=objexcel.cells(2,6).value&&专业 inf(4)=objexcel.cells(2,7).value&&班 LOCAL nrow as Number ,i as Number i=0 *MESSAGEBOX("计算行数") *MESSAGEBOX(objexcel.cells(5,1).value) *MESSAGEBOX(VARTYPE(objexcel.cells(22,1).value)) DO WHILE .t. i=i+1 ?objexcel.cells(i,1).value IF !VARTYPE(objexcel.cells(i,1).value)="C" nrow=i-1 EXIT ENDIF ENDDO *nrow=20 LOCAL arecord(16) *MESSAGEBOX("循环添加记录") USE zlb disinf("zlb.dbf中现有记录"+ALLTRIM(STR(RECCOUNT()))+"条") disinf("正在添加记录") FOR i=4 TO nrow arecord(1)=objexcel.cells(i,1).value&&学号  arecord(2)=objexcel.cells(i,2).value&&姓名 arecord(3)=objexcel.cells(i,3).value&&性别 arecord(4)=objexcel.cells(i,4).value&&籍贯 arecord(5)=objexcel.cells(i,5).value&&民族 *MESSAGEBOX(VARTYPE(objexcel.cells(i,6).value)) IF VARTYPE(objexcel.cells(i,6).value)="C" arecord(6)=RIGHT(objexcel.cells(i,6).value,2)+"/"+"01"+'/'; +LEFT(objexcel.cells(i,6).value,2) ELSE arecord(6)= RIGHT(STR(objexcel.cells(i,6).value,5,2),2); +"/"+"01"+"/"; +LEFT(STR(objexcel.cells(i,6).value,5,2),2) ENDIF &&arecord(6)=IIF(VARTYPE(objexcel.cells(i,6).value)="c",RIGHT(objexcel.cells(i,6).value,2)+"/"+"01"+'/'+LEFT(objexcel.cells(i,6).value,2),; RIGHT(STR(objexcel.cells(i,6).value,5,2),2)+"/"+"01"+'/'+LEFT(STR(objexcel.cells(i,6).value,5,2),2))&&出生年月 arecord(7)=LEFT(ALLTRIM(STR(objexcel.cells(i,8).value,6,0)),6)&&邮政编码 arecord(8)=objexcel.cells(i,7).value&&通讯地址 arecord(9)=objexcel.cells(i,9).value &&收信人 arecord(10)=iif(!ALLTRIM(objexcel.cells(i,10).value)=="",objexcel.cells(i,10).value; ,"无")&&家庭电话 arecord(11)=inf(3)&&专业 arecord(12)=inf(4)&&班级 arecord(13)=objexcel.cells(i,11).value&&寝室号码 arecord(14)=STR(objexcel.cells(i,12).value,7,0)&&寝室电话 arecord(15)=inf(1)&&校区 arecord(16)=inf(2)&&学历 SELECT zlb APPEND FROM ARRAY arecord ENDFOR disinf("zlb.dbf中现有记录"+ALLTRIM(STR(RECCOUNT()))+"条") disinf("记录添加完毕,共添加了"+ALLTRIM(STR(nrow-3))+"条记录,请查检") INKEY(3) WAIT CLEAR ****定义日期转换函数,此函数能将各种格式的日期转换成mm/dd/yy的格式**** ****如果要转换的日期只有年和月,则自动添加日为'01'*** *!* FUNCTION datetran *!* PARAMETERS soudate *!* IF VARTYPE(soudate)="N" *!* DO case *!* CASE LEN(souDATE) ***关闭工作簿,退出EXCEL objexcel.quit RELEASE objexcel *!* objexcel.save *!* *objExcel.ActiveWorkbook.saved=.f. *!* objexcel.Quit &&退出 *!* RELEASE objexcel *!* retu
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值