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
  • 移動開發(一):使用.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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...