当前位置: 首页 > news >正文

做网站关于我们免费自媒体网站

做网站关于我们,免费自媒体网站,珠海网站建设哪家权威,广东模板建站平台版权声明:本文为博主原创文章,转载请在显著位置标明本文出处以及作者网名,未经作者允许不得用于商业目的。 【例 21.7】【项目:code21-007】填充职员表并打印。 本例使用到的Excel文件为:职员信息登记表.xlsx&#x…

版权声明:本文为博主原创文章,转载请在显著位置标明本文出处以及作者网名,未经作者允许不得用于商业目的。

【例 21.7【项目:code21-007】填充职员表并打印。

本例使用到的Excel文件为:职员信息登记表.xlsx,如下图所示:

图21-10 职员信息登记表

窗体设计如下图所示(注意:为了演示方便,已经填充了数据):

图21-11 窗体设计

在本例中还需要掌握的知识:

1、插入图片到指定位置

Worksheet.Shapes.AddPicture(Filename, LinkToFile, SaveWithDocument, Left, Top, Width, Height);

参数说明:

  1. Filename:必选,图片全路径。
  2. LinkToFile:必选,如果为True,则建立图片与其源文件之间的链接关系。否则,使图片成为其源文件的独立副本。通常设置为True。
  3. SaveWithDocument:必选,如果是True,则将图片与文档一起保存。否则,只链接到图片文件。通常设置为True。
  4. Left:必选,图片左上角相对于文档左上角的位置(以磅为单位)。
  5. Top:必选,图片左上角相对于文档顶部的位置(以磅为单位)。
  6. Width:必选,图片的宽度(以磅为单位)。
  7. Height:必选,图片的高度(以磅为单位)。

返回值:

  1. 一个代表新图片的Shape对象。

2、打印输出

Worksheet.PrintOutEx(From, To, Copies, Preview, ActivePrinter, PrintToFile, Collate, PrToFileName, IgnorePrintAreas);

参数说明:

  1. From:可选,打印的开始页号。如果省略此参数,则从起始位置开始打印。
  2. To:可选,打印的终止页号。如果省略此参数,则打印至最后一页。
  3. Copies:可选,打印份数。如果省略此参数,则只打印一份。
  4. Preview:可选,如果为 True,将在打印前调用打印预览。如果为 False(或省略该参数),则立即打印。
  5. ActivePrinter:可选,设置活动打印机的名称,如果不设置,将使用默认打印机。
  6. PrintToFile:可选,如果为True,则打印到文件。如果没有指定 PrToFileName,将提示用户输入要使用的输出文件的文件名。
  7. Collate:可选,如果为True,则逐份打印多个副本。
  8. PrToFileName:可选,如果PrintToFile 设为True,则该参数指定要打印到的文件名。
  9. IgnorePrintAreas:可选,如果为True,则忽略打印区域并打印整个对象。

具体代码如下:

        //需要套用的模板文件

        string modelFile = "c:\\lessons\\职员信息登记表.xlsx";

        //输出Excel文件

        private void Button1_Click(object sender, EventArgs e)

        {

            //获得excel文件输出路径

            string modelfilePath = (new FileInfo(modelFile)).Directory.FullName;

            Microsoft.Office.Interop.Excel.Application xls = new Microsoft.Office.Interop.Excel.Application();

            Workbook Wbook = xls.Workbooks.Open(modelFile);

            Worksheet Wsheet;

            Wsheet = Wbook.Worksheets["sheet1"];

            //填充工作表各个单元格

            Wsheet.Cells[2, 2].value = txtXm.Text;

            Wsheet.Cells[2, 4].value = txtXb.Text;

            Wsheet.Cells[2, 6].value = txtMz.Text;

            Wsheet.Cells[2, 8].value = txtCsny.Text;

            Wsheet.Cells[3, 2].value = txtJkzk.Text;

            Wsheet.Cells[3, 4].value = txtSg.Text;

            Wsheet.Cells[3, 6].value = txtJg.Text;

            Wsheet.Cells[3, 8].value = txtHyzk.Text;

            Wsheet.Cells[4, 2].value = txtWhcd.Text;

            Wsheet.Cells[4, 4].value = txtByyx.Text;

            Wsheet.Cells[4, 7].value = txtSxzy.Text;

            Wsheet.Cells[5, 2].value = txtGzbm.Text;

            Wsheet.Cells[5, 4].value = txtZw.Text;

            Wsheet.Cells[5, 6].value = txtRzsj.Text;

            Wsheet.Cells[5, 8].value = txtZc.Text;

            Wsheet.Cells[6, 2].value = txtLxdz.Text;

            Wsheet.Cells[6, 5].value = txtLxdh.Text;

            Wsheet.Cells[7, 2].value = txtGrjl.Text;

            Wsheet.Cells[8, 2].value = txtQk.Text;

            Wsheet.Cells[9, 2].value = txtGrtc.Text;

            //插入图片

            int picWidth, picHeight;

            int picTop, picLeft;

            //图片高宽比单元格小4,注意由于是一个合并单元格,这里使用了MergeArea

            picWidth = (int)Wsheet.Range["I2"].MergeArea.Width - 4;

            picHeight = (int)Wsheet.Range["I2"].MergeArea.Height - 4;

            //图片左上角位置增加2

            picTop = (int)Wsheet.Range["I2"].Top + 2;

            picLeft = (int)Wsheet.Range["I2"].Left + 2;

            //插入图片

            Microsoft.Office.Interop.Excel.Shape picShape;

            //插入的图片位于Employee目录下,以职员名称命名

            picShape = Wsheet.Shapes.AddPicture(modelfilePath + "\\Employee\\" + txtXm.Text + ".jpg",

                 MsoTriState.msoTrue, MsoTriState.msoTrue, picLeft, picTop, picWidth, picHeight);

            //按照职员姓名保存文件

            Wbook.SaveAs(modelfilePath + "\\" + txtXm.Text + ".xlsx");   

            xls.Quit();

            MessageBox.Show("输出完成");

        }

        //打印

        private void Button2_Click(object sender, EventArgs e)

        {

            string modelfilePath = (new FileInfo(modelFile)).Directory.FullName;

            string xlsEmployeeFile = modelfilePath + "\\" + txtXm.Text + ".xlsx";

            string printFile = modelfilePath + "\\" + txtXm.Text + "1.oxps";

            Microsoft.Office.Interop.Excel.Application xls = new Microsoft.Office.Interop.Excel.Application();

            Workbook Wbook = xls.Workbooks.Open(xlsEmployeeFile);

            Worksheet Wsheet = Wbook.Worksheets[1];

            //可以使用PageSetup.Pages.Cpount获得总的页数,但是Excel要消耗时间和资源

            //这里由于只有一页,可以不考虑使用PageSetup.Pages.Cpount

            int pagecount = 1;   // Wsheet.PageSetup.Pages.Count

            //开始打印

            Wsheet.PrintOutEx(1, pagecount, 1, false, xls.ActivePrinter, true, true, printFile, true);

            xls.Quit();

            MessageBox.Show("打印完成");

        }

当按下“输出”按钮,将输出对应职员信息并保存为职员名字的xlsx文件。

当按下“打印”按钮,将输出的xlsx文件使用默认打印机进行打印,由于笔者计算机没有连接真实打印机,使用默认的“Microsoft XPS Document Writer”打印到文件,如果使用真实打印机,请修改PrintOutEx方法的参数,使之符合打印。

生成的xlsx文件效果如下:

图21-12 保存的Excel文件中的数据

打印的效果如下:

图21-13 打印生成的文件

本例中更适合从数据库中读取数据填入Excel中并打印,读取数据库填充数据,请参看第21.2.2节。还可以将输出数据与打印相结合,省略文件保存的步骤。

 

学习更多vb.net知识,请参看vb.net 教程 目录

学习更多C#知识,请参看C#教程 目录

http://www.15wanjia.com/news/1403.html

相关文章:

  • 网站开发的相关岗位app 推广
  • 网页升级访问升级黑帽seo是什么
  • 有没有帮人做CAD的网站搜索引擎营销的作用
  • 郑州做网站费用怎么优化整站
  • 陕icp网站建设seo关键词快速提升软件官网
  • 个人网站建设优化广州网站关键词排名
  • 个人网站设计需求分析电商网站链接买卖
  • 物流网站公司怎样把产品放到网上销售
  • 网站模板下载百度云链接怎么做的14个seo小技巧
  • 做网站首页ps分辨率多少抖音关键词优化排名靠前
  • 推荐几个响应式网站做参考点击器
  • 以美食为主的网站栏目怎么做搜索引擎在线观看
  • 做啤酒最全的网站企业qq和个人qq有什么区别
  • 莱阳网站开发什么叫友情链接
  • 网站维护与建设ppt苏州关键词优化搜索排名
  • 祥云县外卖哪个网站南阳网站优化公司
  • 无锡企业网站建设chatgpt 链接
  • 做外单网站有哪些登封搜索引擎优化
  • 网站用户量河北关键词seo排名
  • 网站的二维码怎么做店铺推广方法
  • 甘肃省建设厅职业资格注册中心网站百度关键词优化怎么做
  • 佛山网站建设报价推广策略怎么写
  • 网站建设方案功能电商网站建设价格
  • 北海 网站制作工营销推广方式
  • 淄博网站建设公司有几家企业邮箱怎么开通注册
  • 做网站乱码武汉网站seo德升
  • 个人资料库网站怎么做网站seo基本流程
  • 百度做网站的服务合同企业网络营销的模式有哪些
  • 企业法人查询免费西安seo管理
  • 网站建设维护杭州免费个人网站建站