博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
C# 添加Excel表单控件(Form Controls)
阅读量:6690 次
发布时间:2019-06-25

本文共 5507 字,大约阅读时间需要 18 分钟。

在Excel中,添加的控件可以和单元格关联,我们可以操作控件来修改单元格的内容,在下面的文章中,将介绍在Excel中添加几种不同的表单控件的方法,包括:

  •  添加文本框(Textbox)
  •  单选按钮(Radio button)
  •  复选框(Checkbox)
  •  组合框(combo Box)

使用工具

PS:下载安装该组件后,注意在项目程序中添加引用Spire.Xls.dll(dll文件可在安装路径下的Bin文件夹中获取),如下图所示

代码示例

【示例1】插入Excel表单控件

步骤1:创建工作表

//实例化一个Workbook类实例,并获取第1个工作表Workbook workbook = new Workbook();Worksheet sheet = workbook.Worksheets[0];//设置表格行高、列宽sheet.Range["A1:F1"].ColumnWidth = 15F;sheet.Range["A1:B12"].RowHeight = 20F;

步骤 2:插入文本框

//插入文本框控件,指定文本框位置、大小以及文本对齐方式sheet.Range["A1"].Text = "姓名:";ITextBoxShape textBox = sheet.TextBoxes.AddTextBox(1, 2, 25, 110); textBox.Text = "John";textBox.HAlignment = CommentHAlignType.Center;textBox.VAlignment = CommentVAlignType.Center;

步骤 3:插入单选按钮

//插入单选按钮,指定单元格位置sheet.Range["A3"].Text = "性别:";IRadioButton radioButton = sheet.RadioButtons.Add(3, 2, 20, 80);radioButton.CheckState = CheckState.Checked;radioButton.Text = "女";radioButton = sheet.RadioButtons.Add(3, 3, 20, 80);radioButton.Text = "男";

步骤 4:插入复选框

//插入复选框并指定单元格位置sheet.Range["A5"].Text = "所在行业:";ICheckBox checkBox = sheet.CheckBoxes.AddCheckBox(5, 2, 18, 65);checkBox.CheckState = CheckState.Checked;checkBox.Text = "教育";checkBox = sheet.CheckBoxes.AddCheckBox(5, 3, 18, 65);checkBox.Text = "医疗";checkBox = sheet.CheckBoxes.AddCheckBox(5, 4, 18, 65);checkBox.Text = "IT";checkBox = sheet.CheckBoxes.AddCheckBox(5, 5, 18, 65);checkBox.Text = "零售";checkBox = sheet.CheckBoxes.AddCheckBox(5, 6, 18, 65);checkBox.Text = "其他";

步骤 5:插入组合框

//插入组合框,并指定单元格位置、大小sheet["A7"].Text = "年龄(段):";sheet["A8"].Text = "<18";sheet["A9"].Text = "18
<30";sheet["A10"].Text = "30
<50";IComboBoxShape comboBox = sheet.ComboBoxes.AddComboBox(7, 2, 23, 100);comboBox.ListFillRange = sheet["A8:A10"];

步骤 6:指定Combox的关联单元格

sheet["A12"].Text = "代表人群类别:";comboBox.LinkedCell = sheet.Range["B12"];comboBox.SelectedIndex = 1;

步骤 7:保存文档

workbook.SaveToFile("AddFormControls.xlsx", ExcelVersion.Version2010);

运行该项目程序,生成文件(可在项目文件夹bin>Debug下查看文档)

全部代码:

using Spire.Xls;using Spire.Xls.Core;using System.Drawing;namespace FormControls_XLS{    class Program    {        static void Main(string[] args)        {            //实例化一个Workbook类实例,并获取第1个工作表            Workbook workbook = new Workbook();            Worksheet sheet = workbook.Worksheets[0];            //设置表格行高、列宽            sheet.Range["A1:F1"].ColumnWidth = 15F;            sheet.Range["A1:B12"].RowHeight = 20F;                        //插入文本框控件,指定文本框位置、大小以及文本对齐方式            sheet.Range["A1"].Text = "姓名:";            ITextBoxShape textBox = sheet.TextBoxes.AddTextBox(1, 2, 25, 110);                      textBox.Text = "John";            textBox.HAlignment = CommentHAlignType.Center;            textBox.VAlignment = CommentVAlignType.Center;            //插入单选按钮,指定单元格位置            sheet.Range["A3"].Text = "性别:";            IRadioButton radioButton = sheet.RadioButtons.Add(3, 2, 20, 80);            radioButton.CheckState = CheckState.Checked;            radioButton.Text = "女";            radioButton = sheet.RadioButtons.Add(3, 3, 20, 80);            radioButton.Text = "男";            //插入复选框并指定单元格位置            sheet.Range["A5"].Text = "所在行业:";            ICheckBox checkBox = sheet.CheckBoxes.AddCheckBox(5, 2, 18, 65);            checkBox.CheckState = CheckState.Checked;            checkBox.Text = "教育";            checkBox = sheet.CheckBoxes.AddCheckBox(5, 3, 18, 65);            checkBox.Text = "医疗";            checkBox = sheet.CheckBoxes.AddCheckBox(5, 4, 18, 65);            checkBox.Text = "IT";            checkBox = sheet.CheckBoxes.AddCheckBox(5, 5, 18, 65);            checkBox.Text = "零售";            checkBox = sheet.CheckBoxes.AddCheckBox(5, 6, 18, 65);            checkBox.Text = "其他";                                    //插入组合框,并指定单元格位置、大小            sheet["A7"].Text = "年龄(段):";            sheet["A8"].Text = "<18";            sheet["A9"].Text = "18
<30"; sheet["A10"].Text = "30
<50"; IComboBoxShape comboBox = sheet.ComboBoxes.AddComboBox(7, 2, 23, 100); comboBox.ListFillRange = sheet["A8:A10"]; //指定组合框的关联单元格 sheet["A12"].Text = "代表人群类别:"; comboBox.LinkedCell = sheet.Range["B12"]; comboBox.SelectedIndex = 1; //保存文档 workbook.SaveToFile("AddFormControls.xlsx", ExcelVersion.Version2010); System.Diagnostics.Process.Start("AddFormControls.xlsx"); } }}
View Code

 

【示例 2】 删除Excel表单控件

 步骤 1:加载文档,并获取指定单元格

Workbook workbook = new Workbook();workbook.LoadFromFile("test.xlsx");Worksheet sheet = workbook.Worksheets[0];

步骤 2:删除组合框

for (int i = 0; i < sheet.ComboBoxes.Count; i++){    sheet.ComboBoxes[i].Remove();}

步骤 3:保存文档

workbook.SaveToFile("RemoveComboBoxes.xlsx", ExcelVersion.Version2010);

 

全部代码:

using Spire.Xls;namespace RemoveFormControl_XLS{    class Program    {        static void Main(string[] args)        {            //创建Workbook实例,加载Excel文档            Workbook workbook = new Workbook();            workbook.LoadFromFile("test.xlsx");            //获取第一个工作表            Worksheet sheet = workbook.Worksheets[0];            //删除工作表中所有的组合框            for (int i = 0; i < sheet.ComboBoxes.Count; i++)            {                sheet.ComboBoxes[i].Remove();            }            //保存并打开文档            workbook.SaveToFile("RemoveComboBoxes.xlsx", ExcelVersion.Version2010);            System.Diagnostics.Process.Start("RemoveComboBoxes.xlsx");        }    }}
View Code

运行程序后,表格中相应的控件将被删除。

以上是本次关于C#操作Excel表单控件的全部内容,本文完。

(如需转载,请注明出处)

你可能感兴趣的文章
我的友情链接
查看>>
编辑vi 查看网卡命令
查看>>
常见的内存错误及其对策
查看>>
C语言:冒泡法排序一组数,如何优化?
查看>>
分享16个javascript&jQuery的MVC教程
查看>>
使用MediaElement.js构建个性的HTML5音频和视频播放器
查看>>
阿里云域名配置与解析
查看>>
常用的.net开源项目
查看>>
until 循环:实现一个shell脚本,不停地询问用户要执行什么操作,直到用户输入quit才会退出...
查看>>
thinkphp中无法加载数据库驱动
查看>>
MyBatis的xml文件增量热加载,支持多数据源
查看>>
wine安装的软件如何卸载
查看>>
C语言中基本的数据类型 和常用表达式
查看>>
More Fileds的直接输出和获取自定义字段的方法
查看>>
12.1LNMP架构介绍12.2MySQL安装12.312.4 PHP安装12.5Nginx安装
查看>>
ubuntu下安装ROR
查看>>
工作流调度
查看>>
Nginx TCP代理和负载均衡
查看>>
理解原型对象
查看>>
Apache虚拟目录
查看>>