C#實現(xiàn)CSV與PDF和DataTable的快速轉(zhuǎn)換
CSV作為輕量級數(shù)據(jù)載體,在數(shù)據(jù)傳輸中占比超過70%。但其原生格式存在三大痛點:
- 可視化缺陷:無法直接生成可打印的報表
- 結(jié)構(gòu)限制:缺乏數(shù)據(jù)類型定義和關(guān)系約束
- 安全風(fēng)險:易被意外修改導(dǎo)致數(shù)據(jù)失真
因此,我們常常需要將CSV文件轉(zhuǎn)換為PDF格式以便于打印和分享,或者轉(zhuǎn)換為DataTable用于程序化處理。本文將介紹如何利用免費庫 Free Spire.XLS for .NET 高效實現(xiàn)這兩種轉(zhuǎn)換。
一、準(zhǔn)備工作
通過 NuGet 包管理器安裝Free Spire.XLS,打開程序包管理控制臺輸入:
Install-Package FreeSpire.XLS
或在 Visual Studio 中搜索 “FreeSpire.XLS” 安裝最新免費版。
二、C# 代碼: 將CSV轉(zhuǎn)換為PDF
using Spire.Xls;
using System.Drawing;
namespace CSVtoPDF
{
class Program
{
static void Main(string[] args)
{
// 初始化Workbook對象
Workbook workbook = new Workbook();
//加載CSV文件
workbook.LoadFromFile("庫存.csv", ",", 1, 1);
// 獲取第一個工作表
Worksheet sheet = workbook.Worksheets[0];
// 設(shè)置表格樣式
sheet.AllocatedRange.Style.Color = Color.White;
sheet.AllocatedRange.Style.Font.Color = Color.Black;
sheet.AllocatedRange.Style.Font.Size = 11;
sheet.AllocatedRange.AutoFitColumns();
sheet.AllocatedRange.AutoFitRows();
// 設(shè)置表頭樣式
CellRange header = sheet.Range[1, 1, 1, sheet.Columns.Length];
header.Style.Color = Color.LightGreen;
header.Style.Font.IsBold = true;
// 配置PDF導(dǎo)出選項
workbook.ConverterSetting.SheetFitToPage = true;
workbook.ConverterSetting.SheetFitToWidth = true;
workbook.ConverterSetting.JPEGQuality = 100;
// 將CSV文件保存為PDF文件
sheet.SaveToPdf("CSVtoPDF.pdf");
}
}
}
關(guān)鍵功能解析
1.自動格式化
AutoFitColumns()/AutoFitRows()自動調(diào)整行列尺寸- 表頭自動加粗和背景色設(shè)置
2.樣式定制
- 支持字體、顏色、邊框等樣式配置
- 單元格背景色設(shè)置(如
Color.LightGreen)
3.PDF優(yōu)化選項
SheetFitToPage:自動適應(yīng)頁面SheetFitToWidth:寬度自適應(yīng)JPEGQuality:輸出質(zhì)量控制
轉(zhuǎn)換效果圖:

三、C# 代碼: 將CSV轉(zhuǎn)換為DataTable
使用Free Spire.XLS,可以將CSV文件加載到工作簿對象中,獲取指定工作表,然后調(diào)用 ExportDataTable() 方法即可直接轉(zhuǎn)換為DataTable。
using Spire.Xls;
namespace CSVtoDataTable
{
class Program
{
static void Main(string[] args)
{
// 初始化Workbook對象
Workbook workbook = new Workbook();
// 加載CSV到工作簿
workbook.LoadFromFile("庫存.csv", ",", 1, 1);
// 獲取第一個工作表
Worksheet sheet = workbook.Worksheets[0];
// 將第一個工作表導(dǎo)入DataTable
sheet.ExportDataTable();
}
}
}
DataTable優(yōu)勢:
- 內(nèi)存高效處理大數(shù)據(jù)集
- 無縫銜接Pandas生態(tài)
- 支持SQL查詢式數(shù)據(jù)操作
四、應(yīng)用場景
| 轉(zhuǎn)換類型 | 最佳場景 |
|---|---|
| CSV轉(zhuǎn)PDF | 審計報告/打印文檔/存檔記錄 |
| CSV轉(zhuǎn)DataTable | 數(shù)據(jù)清洗/管理后臺/實時分析 |

五、結(jié)論
通過Free Spire.XLS for .NET實現(xiàn)CSV轉(zhuǎn)換:
- PDF導(dǎo)出 - 生成專業(yè)級可打印文檔
- DataTable轉(zhuǎn)換 - 實現(xiàn)高效內(nèi)存數(shù)據(jù)處理
- 免費高效 - 無需Excel環(huán)境依賴
提示:商業(yè)場景可考慮商業(yè)版,解除限制并獲得高級功能支持。
到此這篇關(guān)于C#實現(xiàn)CSV與PDF和DataTable的快速轉(zhuǎn)換的文章就介紹到這了,更多相關(guān)C# CSV與PDF和DataTable的轉(zhuǎn)換內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
詳解C#批量插入數(shù)據(jù)到Sqlserver中的四種方式
本文主要講解一下在Sqlserver中批量插入數(shù)據(jù)。文中大數(shù)據(jù)批量插入方式一和方式四盡量避免使用,而方式二和方式三都是非常高效的批量插入數(shù)據(jù)方式,需要的朋友可以看下2016-12-12
C#中實現(xiàn)線程同步lock關(guān)鍵字的用法詳解
實現(xiàn)線程同步的第一種方式是我們經(jīng)常使用的lock關(guān)鍵字,它將包圍的語句塊標(biāo)記為臨界區(qū),這樣一次只有一個線程進(jìn)入臨界區(qū)并執(zhí)行代碼,接下來通過本文給大家介紹C#中實現(xiàn)線程同步lock關(guān)鍵字的用法詳解,一起看看吧2016-07-07

