欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C#中給Excel添加水印的具體方法

 更新時間:2016年09月28日 10:35:41   作者:Yesi  
這篇文章主要介紹了C#中如何給Excel添加水印,具有一定的參考價值,感興趣的小伙伴們可以參考一下

我們知道Microsoft Excel并沒有內(nèi)置的功能直接給Excel表添加水印,但是其實我們可以用其他變通的方式來解決此問題,如通過添加頁眉圖片或藝術(shù)字的方法來模仿水印的外觀。所以在這篇文章中,我將向您演示來如何通過在Excel中創(chuàng)建和插入頁眉圖片來為excel添加水印。之前我也分享了如何給word文檔添加水印和pdf文件添加水印的方法,有需要也可以參考。

這里我下載了一個E-iceblue公司開發(fā)的免費版的Excel組件- Free Spire.XLS,這樣既節(jié)省時間,又簡化了代碼。

控件安裝后,創(chuàng)建項目,添加安裝目錄下的dll文件作為項目的引用,并添加如下命名空間:

using System;
using System.Drawing;
using System.Windows.Forms;
using Spire.Xls; 

這是原excel表的截圖:

以下是詳細步驟和代碼片段:

步驟1:首先定義一個DrawText()方法,并在字符串的內(nèi)容基礎(chǔ)上創(chuàng)建一個圖片。字符串可以是“機密”、“草稿”、“樣品”或任何你想要顯示為水印的文本。

private static System.Drawing.Image DrawText(String text, System.Drawing.Font font, Color textColor, Color backColor, double height, double width) <br>{
 //創(chuàng)建一個指定寬度和高度的位圖圖像
 Image img = new Bitmap((int)width, (int)height);
 Graphics drawing = Graphics.FromImage(img);
 //獲取文本大小
 SizeF textSize = drawing.MeasureString(text, font);
 //旋轉(zhuǎn)圖片
 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);
 //創(chuàng)建文本刷
 Brush textBrush = new SolidBrush(textColor);
 drawing.DrawString(text, font, textBrush, ((int)width - textSize.Width) / 2, ((int)height - textSize.Height) / 2);
 drawing.Save();
 return img;
}

 步驟2:初始化一個新的工作簿并加載添加水印的文件。

Workbook workbook = new Workbook();
workbook.LoadFromFile(@"C:\Users\Administrator\Desktop\sample.xlsx");

步驟3:調(diào)用DrawText()方法新建一個圖片,并將頁眉圖片設(shè)置為左對齊。其次,因為在視圖模式是布局的狀態(tài)下頁眉圖片才會顯示,所以一定要記得將視圖模式改為布局。

Font font = new System.Drawing.Font("arial", 40);
String watermark = "內(nèi)部資料";
foreach (Worksheet sheet in workbook.Worksheets)
{
 //調(diào)用DrawText()方法新建圖片
 System.Drawing.Image imgWtrmrk = DrawText(watermark, font, System.Drawing.Color.LightCoral, System.Drawing.Color.White, sheet.PageSetup.PageHeight, sheet.PageSetup.PageWidth);
 //將頁眉圖片設(shè)置為左對齊
 sheet.PageSetup.LeftHeaderImage = imgWtrmrk;
 sheet.PageSetup.LeftHeader = "&G";
 //水印只會在此種模式下顯現(xiàn)
 sheet.ViewMode = ViewMode.Layout;
 }

步驟4:保存并打開文件。

workbook.SaveToFile("水印.xlsx", ExcelVersion.Version2010);
System.Diagnostics.Process.Start("水印.xlsx");

 效果圖:

全部代碼:

using System;
using System.Drawing;
using System.Windows.Forms;
using Spire.Xls;
 
namespace Add_Watermark_To_Excel
{
 public partial class Form1 : Form
 {
  public Form1()
  {
   InitializeComponent();
  }
 
  private void button1_Click(object sender, EventArgs e)
  {
   //初始化一個新工作簿并加載要添加水印的文件
   Workbook workbook = new Workbook();
   workbook.LoadFromFile(@"C:\Users\Administrator\Desktop\sample.xlsx");
   //在頁眉插入圖片
   Font font = new System.Drawing.Font("arial", 40);
   String watermark = "內(nèi)部資料";
   foreach (Worksheet sheet in workbook.Worksheets)
   {
    //調(diào)用DrawText()方法新建圖片
    System.Drawing.Image imgWtrmrk = DrawText(watermark, font, System.Drawing.Color.LightCoral, System.Drawing.Color.White, sheet.PageSetup.PageHeight, sheet.PageSetup.PageWidth);
    //將頁眉圖片設(shè)置為左對齊
    sheet.PageSetup.LeftHeaderImage = imgWtrmrk;
    sheet.PageSetup.LeftHeader = "&G";
    //水印只會在此種模式下顯現(xiàn)
    sheet.ViewMode = ViewMode.Layout;
   }
   workbook.SaveToFile("水印.xlsx", ExcelVersion.Version2010);
   System.Diagnostics.Process.Start("水印.xlsx");
  }
  <br>  private static System.Drawing.Image DrawText(String text, System.Drawing.Font font, Color textColor, Color backColor, double height, double width)
  {
   //創(chuàng)建一個指定寬度和高度的位圖圖像
   Image img = new Bitmap((int)width, (int)height);
   Graphics drawing = Graphics.FromImage(img);
   //獲取文本大小
   SizeF textSize = drawing.MeasureString(text, font);
   //旋轉(zhuǎn)圖片
   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);
   //創(chuàng)建文本刷
   Brush textBrush = new SolidBrush(textColor);
   drawing.DrawString(text, font, textBrush, ((int)width - textSize.Width) / 2, ((int)height - textSize.Height) / 2);
   drawing.Save();
   return img;
  }
 
 } 
}

 感謝您的瀏覽,希望本文能給您帶來一定的幫助。

相關(guān)文章

  • Unity?UGUI的GraphicRaycaster射線投射組件介紹使用

    Unity?UGUI的GraphicRaycaster射線投射組件介紹使用

    這篇文章主要為大家介紹了Unity?UGUI的GraphicRaycaster射線投射組件介紹使用,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-07-07
  • c#圖片處理之圖片裁剪成不規(guī)則圖形

    c#圖片處理之圖片裁剪成不規(guī)則圖形

    最近項目要求實現(xiàn)不規(guī)則裁剪功能。本來想用html5的canvas在前端實現(xiàn)的,但是發(fā)現(xiàn)有點困難,以下為C#端對圖對片的處理
    2014-05-05
  • c# WPF中自定義加載時實現(xiàn)帶動畫效果的Form和FormItem

    c# WPF中自定義加載時實現(xiàn)帶動畫效果的Form和FormItem

    這篇文章主要介紹了c# WPF中自定義加載時實現(xiàn)帶動畫效果的Form和FormItem,幫助大家更好的理解和學(xué)習(xí)使用c#,感興趣的朋友可以了解下
    2021-03-03
  • C# 設(shè)計模式之單例模式歸納總結(jié)

    C# 設(shè)計模式之單例模式歸納總結(jié)

    這篇文章主要介紹了C#設(shè)計模式之單例模式實例講解,本文講解了單例模式的定義、單例模式的優(yōu)缺點,需要的朋友可以參考下
    2017-04-04
  • C#中委托的基本概念介紹

    C#中委托的基本概念介紹

    這篇文章主要介紹了C#中委托的基本概念介紹,本文講解了委托的使用、委托類型和委托實例、委托的合并和刪除、委托是不易變的、委托調(diào)用列表、GetInvocationList等內(nèi)容,需要的朋友可以參考下
    2015-02-02
  • Unity實現(xiàn)圖片輪播組件

    Unity實現(xiàn)圖片輪播組件

    這篇文章主要為大家詳細介紹了Unity實現(xiàn)圖片輪播組件的相關(guān)方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-03-03
  • 詳解c# PLINQ中的分區(qū)

    詳解c# PLINQ中的分區(qū)

    這篇文章主要介紹了c# PLINQ中的分區(qū)的相關(guān)資料,文中示例代碼非常詳細,幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下
    2020-07-07
  • C#實現(xiàn)動態(tài)數(shù)據(jù)繪圖graphic的方法示例

    C#實現(xiàn)動態(tài)數(shù)據(jù)繪圖graphic的方法示例

    這篇文章主要介紹了C#實現(xiàn)動態(tài)數(shù)據(jù)繪圖graphic的方法,結(jié)合實例形式分析了C#根據(jù)動態(tài)數(shù)據(jù)繪制2D數(shù)據(jù)表格的相關(guān)操作技巧,需要的朋友可以參考下
    2017-09-09
  • C#中ManualResetEvent用法總結(jié)

    C#中ManualResetEvent用法總結(jié)

    這篇文章主要介紹了C#中ManualResetEvent用法總結(jié),幫助大家更好的理解和使用c#,感興趣的朋友可以了解下
    2021-01-01
  • c# 網(wǎng)址壓縮簡單實現(xiàn)短網(wǎng)址

    c# 網(wǎng)址壓縮簡單實現(xiàn)短網(wǎng)址

    短網(wǎng)址,忽然一下子就冒出來的東西,長長的一個URL,提交過去,出來就只有短短的一個URL了,看起來似乎挺神奇,其實簡單分析一下,明白其中的原理,也是一件很簡單的事情,需要的朋友可以了解下
    2012-12-12

最新評論