C#/VB.NET 在Excel中添加水印

来源:https://www.cnblogs.com/Carina-baby/archive/2023/01/19/17061732.html
-Advertisement-
Play Games

在工作中,為了防止文件被隨意複製和傳播,通常我們會選擇在文檔中添加水印來對文件進行有效保護。文字水印是比較常見的一種保護手段,它可以有效防止文件被任意複製和隨意列印傳播。不過,Excel預設並沒有水印功能。此時,我們可以把插入的藝術字作為水印,將水印和工作表融合在一起,以防止文檔被覆制傳播。那麼如何 ...


在工作中,為了防止文件被隨意複製和傳播,通常我們會選擇在文檔中添加水印來對文件進行有效保護。文字水印是比較常見的一種保護手段,它可以有效防止文件被任意複製和隨意列印傳播。不過,Excel預設並沒有水印功能。此時,我們可以把插入的藝術字作為水印,將水印和工作表融合在一起,以防止文檔被覆制傳播。那麼如何輕鬆實現在Excel中添加水印呢?彆著急,我給大家整理了一個高效便捷的方法,通過編程方式達到此目的。下麵是我整理的具體步驟,並附上C#/VB.NET代碼供大家參考。

程式環境:

本次測試時,在程式中引入 Spire.XLS.dll 文件。

方法1:

Free Spire.XLS for .NET​​ 下載到本地,解壓,找到 BIN 文件夾下的 Spire.XLS.dll。然後在 Visual Studio 中打開“解決方案資源管理器”,滑鼠右鍵點擊“引用”,“添加引用”,將本地路徑 BIN 文件夾下的 dll 文件添加引用至程式。

方法2::

通過​NuGet​​安裝。可通過以下 2 種方法安裝:

 1. 可以在 Visual Studio 中打開“解決方案資源管理器”,滑鼠右鍵點擊“引用”,“管理 NuGet 包”,然後搜索“Free Spire.XLS”,點擊“安裝”。等待程式安裝完成。

 2. 將以下內容複製到 PM 控制台安裝。

Install-Package FreeSpire.XLS -Version 12.7

在Excel中添加水印

以下是詳細步驟:

  • 創建Workbook類的實例。
  • 使用 Workbook.LoadFromFile() 方法載入 Excel 文件。
  • 創建字體並定義文本。
  • 遍歷 Excel 文件中的所有工作表。
  • 使用 DrawWatermarkImage() 方法創建基於文本的水印圖像。
  • 通過Worksheet.PageSetup.LeftHeaderImage 屬性將圖片設置為每個工作表左頁眉的圖像源。
  • 將 Worksheet.PageSetup.LeftHeader 屬性設置為“&G”,在左側標題部分顯示圖像。
  • 將工作表的查看模式更改為頁面佈局,以便查看水印。
  • 使用 Workbook.SaveToFile() 方法保存結果文件。

完整代碼

C#

using Spire.Xls;
using System.Drawing;

namespace AddWatermark
{
    class Program
    {
        static void Main(string[] args)
        {
            //初始化 Workbook 類的實例並載入 Excel 文件
            Workbook workbook = new Workbook();
            workbook.LoadFromFile("示例文檔.xlsx");

            //創建字體
            Font font = new Font("宋體", 40);
            //定義文本
            string watermark = "內部使用";

            //遍歷文件中的所有工作表
            foreach (Worksheet sheet in workbook.Worksheets)
            {
                //調用 DrawWatermarkImage() 方法根據文本創建圖像
                Image imgWtrmrk = DrawWatermarkImage(watermark, font, Color.LightCoral, Color.White, sheet.PageSetup.PageHeight, sheet.PageSetup.PageWidth);

                //將圖像添加到每個工作表的左側標題部分
                sheet.PageSetup.LeftHeaderImage = imgWtrmrk;
                sheet.PageSetup.LeftHeader = "&G";

                //將工作表的查看模式更改為頁面佈局以查看水印
                sheet.ViewMode = ViewMode.Layout;
            }

            //保存結果文件
            workbook.SaveToFile("添加水印.xlsx", ExcelVersion.Version2013);
        }

        private static Image DrawWatermarkImage(string text, Font font, Color textColor, Color backColor, double height, double width)
        {
            //創建具有指定寬度和高度的圖像
            Image img = new Bitmap((int)width, (int)height);
            //從圖像創建一個 Graphics 對象
            Graphics drawing = Graphics.FromImage(img);

            //獲取文字的大小
            SizeF textSize = drawing.MeasureString(text, font);

            //通過將指定的轉換前置到圖形的變換矩陣來更改坐標系統的原點
            drawing.TranslateTransform(((int)width - textSize.Width) / 2, ((int)height - textSize.Height) / 2);

            //應用旋轉
            drawing.RotateTransform(-45);

            //通過將指定的轉換前置到圖形的變換矩陣來更改坐標系統的原點
            drawing.TranslateTransform(-((int)width - textSize.Width) / 2, -((int)height - textSize.Height) / 2);

            //繪製背景
            drawing.Clear(backColor);

            //為文本創建畫筆
            Brush textBrush = new SolidBrush(textColor);

            //將文本繪製到圖形的中心位置
            drawing.DrawString(text, font, textBrush, ((int)width - textSize.Width) / 2, ((int)height - textSize.Height) / 2);
            drawing.Save();
            return img;
        }
    }
}

VB.NET

Imports Spire.Xls
Imports System.Drawing

Namespace AddWatermark
    Friend Class Program
        Private Shared Sub Main(ByVal args As String())
            '初始化 Workbook 類的新實例並載入 Excel 文件
            Dim workbook As Workbook = New Workbook()
            workbook.LoadFromFile("示例文檔.xlsx")

            '創建字體
            Dim font As Font = New Font("宋體", 40)
            '定義文本
            Dim watermark = "內部使用"

            '遍歷文件中的所有工作表
            For Each sheet As Worksheet In workbook.Worksheets
                '調用 DrawWatermarkImage() 方法根據文本創建圖像
                Dim imgWtrmrk As Image = DrawWatermarkImage(watermark, font, Color.LightCoral, Color.White, sheet.PageSetup.PageHeight, sheet.PageSetup.PageWidth)

                '將圖像添加到每個工作表的左側標題部分
                sheet.PageSetup.LeftHeaderImage = imgWtrmrk
                sheet.PageSetup.LeftHeader = "&G"

                '將工作表的查看模式更改為頁面佈局以查看水印
                sheet.ViewMode = ViewMode.Layout
            Next

            '保存結果文件
            workbook.SaveToFile("添加水印.xlsx", ExcelVersion.Version2013)
        End Sub

        Private Shared Function DrawWatermarkImage(ByVal text As String, ByVal font As Font, ByVal textColor As Color, ByVal backColor As Color, ByVal height As Double, ByVal width As Double) As Image
            '創建具有指定寬度和高度的圖像
            Dim img As Image = New Bitmap(width, height)
            '從圖像創建一個 Graphics 對象
            Dim drawing As Graphics = Graphics.FromImage(img)

            '獲取文字的大小
            Dim textSize As SizeF = drawing.MeasureString(text, font)

            '通過將指定的轉換前置到圖形的變換矩陣來更改坐標系統的原點
            drawing.TranslateTransform((CInt(width) - textSize.Width) / 2, (CInt(height) - textSize.Height) / 2)

            '應用旋轉
            drawing.RotateTransform(-45)

            '通過將指定的轉換前置到圖形的變換矩陣來更改坐標系統的原點
            drawing.TranslateTransform(-(CInt(width) - textSize.Width) / 2, -(CInt(height) - textSize.Height) / 2)

            '繪製背景
            drawing.Clear(backColor)

            '為文本創建畫筆
            Dim textBrush As Brush = New SolidBrush(textColor)

            '將文本繪製到圖形的中心位置
            drawing.DrawString(text, font, textBrush, (CInt(width) - textSize.Width) / 2, (CInt(height) - textSize.Height) / 2)
            drawing.Save()
            Return img
        End Function
    End Class
End Namespace

效果圖

—本文完—


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

-Advertisement-
Play Games
更多相關文章
  • Python如何運行程式 Python解釋器簡介 解釋器是一種讓其他程式運行起來的程式。 Python解釋器將讀取程式,並按照其中的命令執行,得出結果。 解釋器是代碼與機器的電腦硬體之間的軟體邏輯層。 解釋器本身可以用C程式實現,或者一些Java類實現。 程式執行 程式員視角 Python程式僅是 ...
  • 2023-01-19 一、SpringMVC簡介 1、SpringMVC是Spring子框架 2、SpringMVC是Spring為“控制層”提供的基於MVC設計理念的優秀的Web框架,是目前最主流的MVC框架。 3、SpringMVC是非侵入式:可以使用註解讓普通java對象,作為請求處理器(Co ...
  • 安裝Go及開發工具介紹 安裝Go 安裝過程非常簡單,下載自己系統對應的安裝包後直接安裝即可。安裝路徑中包含空格不會對Go環境有影響,在windows系統中,安裝到預設Program Files或Program Files (x86)即可,也可以根據自己需要改變安裝目錄。 安裝完成後,開啟一個新的cm ...
  • 淘汰策略概述 redis作為緩存使用時,在添加新數據的同時自動清理舊的數據。這種行為在開發者社區眾所周知,也是流行的memcached系統的預設行為。 redis中使用的LRU淘汰演算法是一種近似LRU的演算法。 淘汰策略 針對淘汰策略,redis有一下幾種配置方案: 1、noeviction:當觸發內 ...
  • 眾所周知,PDF文檔除了具有較強穩定性和相容性外, 還具有較強的安全性,在工作中可以有效避免別人無意中對文檔內容進行修改。但與此同時,也妨礙了對文檔的正常的修改。這時我們可以將PDF轉為Word文檔進行修改或再編輯。使用軟體將 PDF 文檔轉換為 Word 文檔十分簡單,然而要在轉換時保持佈局甚至字 ...
  • Loj鏈接:接竹竿 $ {\scr \color {SkyBlue}{\text{Solution}}} $ 題目大意: 給定一個數組,每次加入一種顏色的數,可以取走與它顏色相同的兩個數之間的所有數,問最後取走的所有數中最大和是多少 分析: 第一眼看到的是二分答案,但不知道二分的check()函數怎 ...
  • 2023-01-19 Spring聲明式事務管理屬性 一、隔離級別 1、概念:一個事務與其他事務之間的隔離等級(1,2,4,8)。 2、隔離級別: (1)讀未提交(1):READ UNCOMMTTED 存在問題:臟讀(讀取到了未提交數據) (2)讀已提交(2):READ COMMTTED 存在問題: ...
  • 概述 web管理系統中可以對業務數據執行新增和刪除,現在需要當業務數據發生新增或刪除操作後,儘可能實時的反應到WPF客戶端上面。 web管理系統用VUE編寫,後端服務為SpringBoot,WPF客戶端基於.Netframework4.8編寫。 整體架構 sequenceDiagram title: ...
一周排行
    -Advertisement-
    Play Games
  • 下麵是一個標準的IDistributedCache用例: public class SomeService(IDistributedCache cache) { public async Task<SomeInformation> GetSomeInformationAsync (string na ...
  • 這個庫提供了在啟動期間實例化已註冊的單例,而不是在首次使用它時實例化。 單例通常在首次使用時創建,這可能會導致響應傳入請求的延遲高於平時。在註冊時創建實例有助於防止第一次Request請求的SLA 以往我們要在註冊的時候實例單例可能會這樣寫: //註冊: services.AddSingleton< ...
  • 最近公司的很多項目都要改單點登錄了,不過大部分都還沒敲定,目前立刻要做的就只有一個比較老的項目 先改一個試試手,主要目標就是最短最快實現功能 首先因為要保留原登錄方式,所以頁面上的改動就是在原來登錄頁面下加一個SSO登錄入口 用超鏈接寫的入口,頁面改造後如下圖: 其中超鏈接的 href="Staff ...
  • Like運算符很好用,特別是它所提供的其中*、?這兩種通配符,在Windows文件系統和各類項目中運用非常廣泛。 但Like運算符僅在VB中支持,在C#中,如何實現呢? 以下是關於LikeString的四種實現方式,其中第四種為Regex正則表達式實現,且在.NET Standard 2.0及以上平... ...
  • 一:背景 1. 講故事 前些天有位朋友找到我,說他們的程式記憶體會偶發性暴漲,自己分析了下是非托管記憶體問題,讓我幫忙看下怎麼回事?哈哈,看到這個dump我還是非常有興趣的,居然還有這種游戲幣自助機類型的程式,下次去大玩家看看他們出幣的機器後端是不是C#寫的?由於dump是linux上的程式,剛好win ...
  • 前言 大家好,我是老馬。很高興遇到你。 我們為 java 開發者實現了 java 版本的 nginx https://github.com/houbb/nginx4j 如果你想知道 servlet 如何處理的,可以參考我的另一個項目: 手寫從零實現簡易版 tomcat minicat 手寫 ngin ...
  • 上一次的介紹,主要圍繞如何統一去捕獲異常,以及為每一種異常添加自己的Mapper實現,並且我們知道,當在ExceptionMapper中返回非200的Response,不支持application/json的響應類型,而是寫死的text/plain類型。 Filter為二方包異常手動捕獲 參考:ht ...
  • 大家好,我是R哥。 今天分享一個爽飛了的面試輔導 case: 這個杭州兄弟空窗期 1 個月+,面試了 6 家公司 0 Offer,不知道問題出在哪,難道是杭州的 IT 崩盤了麽? 報名面試輔導後,經過一個多月的輔導打磨,現在成功入職某上市公司,漲薪 30%+,955 工作制,不咋加班,還不捲。 其他 ...
  • 引入依賴 <!--Freemarker wls--> <dependency> <groupId>org.freemarker</groupId> <artifactId>freemarker</artifactId> <version>2.3.30</version> </dependency> ...
  • 你應如何運行程式 互動式命令模式 開始一個互動式會話 一般是在操作系統命令行下輸入python,且不帶任何參數 系統路徑 如果沒有設置系統的PATH環境變數來包括Python的安裝路徑,可能需要機器上Python可執行文件的完整路徑來代替python 運行的位置:代碼位置 不要輸入的內容:提示符和註 ...