C# 添加Excel表單控制項(Form Controls)

来源:https://www.cnblogs.com/Yesi/archive/2018/12/05/10071267.html
-Advertisement-
Play Games

在Excel中,添加的控制項可以和單元格關聯,我們可以操作控制項來修改單元格的內容,在下麵的文章中,將介紹在Excel中添加幾種不同的表單控制項的方法,包括: 添加文本框(Textbox) 單選按鈕(Radio button) 覆選框(Checkbox) 組合框(combo Box) 使用工具 Free ...


在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表單控制項的全部內容,本文完。

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


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 在 Web 應用程式開發過程中,總是無法避免涉及到文件上傳,這次我們來聊一聊怎麼去實現一個簡單方便可復用文件上傳功能;通過創建自定義綁定模型來實現文件上傳。 ...
  • 這裡貼一段VB的代碼,C#參照也是類似的,讀取C盤字體庫中的字體,判斷字體是否存在,不存在即可使用特殊方法對字體進行安裝 這對部分B/S搭建的軟體還是能起到作用的,畢竟有些軟體設置的字體在系統庫中並不存在,如果不安得話,會出現各種亂碼的情況,所以 才需要這麼做 ...
  • 寫在前面 上一篇文章中我帶著大家進行了許可權部分的極簡設計,也僅僅是一個基本的許可權設計。不過你完全可以基於這套許可權系統設計你的更複雜的許可權系統,當然更複雜的許可權系統要根據你的業務來進行,因為任何脫離實際業務的許可權設計都是耍流氓!今天這篇文章我們就對CMS系統的內容進行設計。同時下篇文章準備帶著大家理解 ...
  • 一、委托是什麼? 委托一般可以看作是持有一個或多個方法的對象。可以把委托看做是對象,其和我們使用一個對象的過程一樣。 聲明->創建委托對象->給委托賦值->調用委托。 關於委托還有另一種理解,我們可以把委托類比為C/C++中的函數指針這一概念。只是委托是類型安全的。函數指針就是 指向函數入口地址的一 ...
  • #region 【通過XDocument的方式將Xml文件遞歸到TreeView控制項中】 //讀取Xml文件(XDocument) //1.載入Xml文件 XDocument document=XDoument.Load("文件名稱.xml"); //2.先獲取跟節點 XElement rootEl ...
  • 本文采用Nginx來實現ASP.NET程式集群化。 準備環境 首先準備Nginx環境,Windows版本下載鏈接:http://nginx.org/en/download.html 解壓後文件格式如下: 修改配置文件 打開 conf 文件夾中的 nginx.conf 配置文件 配置說明: 1.lis ...
  • 近日逛招聘軟體,看到部分企業都要求會編寫、請求restFul的webapi。正巧這段時間較為清閑,於是乎打開vs準備開擼。 1.何為restFul? restFul是符合rest架構風格的網路API介面。 rest是一種軟體架構的編碼風格,是根據網路應用而去設計和開發的一種可以降低開發複雜度的編碼方 ...
  • 最近公司項目上線,之前利用串口通訊實現校牌的無感知簽到程式, 項目上線以後剛剛好有時間把之前的出現的問題做下記錄,廢話不多,直接到主題 串口介紹: 串列介面簡稱串口,也稱串列通信介面或串列通訊介面(通常指COM介面),是採用串列通信方式的擴展介面。(至於再詳細,自己百度) 正文: 最近在公司讓用C# ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...