1. 程式人生 > >C# 新增Excel表單控制元件(Form Controls)

C# 新增Excel表單控制元件(Form Controls)

在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<Y<30";
sheet["A10"].Text = "30<Y<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<Y<30";
            sheet["A10"].Text = "30<Y<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表單控制元件的全部內容,本文完。

(如需轉載,請註明出處)