Rust使用rust_xlsxwriter庫把Vec數據寫入Excel

一、Rust使用rust_xlsxwriter庫把一維Vec數據寫入Excel

在Rust中,使用rust_xlsxwriter庫將一維Vec數據寫入Excel文件是一個相對簡單的過程。首先,你需要確保你的Cargo.toml文件中已經添加了rust_xlsxwriter依賴。以下是如何添加依賴的示例:

[dependencies]
rust_xlsxwriter = "0.62.0"  # 請使用最新的版本號

然后,你可以使用以下步驟來將Vec數據寫入Excel文件:

  1. 創建一個新的Excel文件。
  2. 添加一個工作表。
  3. 寫入數據到工作表中。
  4. 保存并關閉Excel文件。

下面是一個簡單的示例代碼,演示如何將包含字符串的一維Vec數據寫入Excel:

use rust_xlsxwriter::Workbook;fn main() {//輸出的文件名let file_name = "output.xlsx";// 創建一個新的Excel工作簿let mut workbook = Workbook::new();// 獲取工作表的可變引用let worksheet = workbook.add_worksheet();// 假設我們有一個Vec<String>類型的數據let data = vec!["Apple".to_string(),"Banana".to_string(),"Cherry".to_string(),];// 寫入數據到工作表中for (row_number, item) in data.iter().enumerate() {// 寫入單元格,參數分別是行號、列號和數據let _ = worksheet.write(row_number as u32, 0, item);}//保存工作簿workbook.save(file_name).expect("保存失敗");//關閉工作簿drop(workbook);
}

如果你的Vec包含更復雜的數據結構,例如包含多個字段的結構體,你可以先將其轉換為一個包含字符串的Vec,然后再寫入Excel,或者自定義寫入邏輯以適應你的數據結構。

請注意,rust_xlsxwriter庫可能不提供與Python的xlsxwriter庫相同的所有功能,因此在使用時需要查看Rust版本的文檔以了解可用的功能和API。此外,示例中使用的版本號0.1.0可能不是最新的,請在Cargo.toml中使用最新的版本號。

二、Rust使用rust_xlsxwriter庫把二維Vec數據寫入Excel

在Rust中,使用rust_xlsxwriter庫將二維Vec數據寫入Excel文件的步驟與寫入一維Vec類似,但你需要對每一行數據進行迭代。下面是一個示例,演示如何將二維Vec數據(例如Vec<Vec<String>>)寫入Excel文件:

首先,確保你的Cargo.toml文件中已經添加了rust_xlsxwriter依賴,并且版本是最新的。

[dependencies]
rust_xlsxwriter = "0.62.0"  # 請檢查并使用最新的版本號

然后,你可以使用以下代碼將二維Vec數據寫入Excel:

use rust_xlsxwriter::Workbook;fn main() {//輸出的文件名let file_name = "output.xlsx";// 創建一個新的Excel工作簿let mut workbook = Workbook::new();// 獲取工作表的可變引用let worksheet = workbook.add_worksheet();// 假設我們有一個二維Vec<String>類型的數據let data = vec![vec!["Apple".to_string(), "Banana".to_string()],vec!["Cherry".to_string(), "Date".to_string()],vec!["Elderberry".to_string(), "Fig".to_string()],];// 遍歷二維Vec的每一行for (row_index, row) in data.iter().enumerate() {// 遍歷行中的每個元素for (col_index, item) in row.iter().enumerate() {// 寫入單元格,參數分別是行號、列號和數據let _ = worksheet.write(row_index as u32, (col_index as u32).try_into().unwrap(), item);}}//保存工作簿workbook.save(file_name).expect("保存失敗");//關閉工作簿drop(workbook);
}

在這個示例中,我們首先創建了一個Excel工作簿,并添加了一個名為"Sheet1"的工作表。然后,我們定義了一個二維Vec,其中包含了一些水果名稱。我們通過嵌套的for循環遍歷這個二維Vec,并將每一行和列的數據寫入到Excel工作表的相應單元格中。

請確保你使用的rust_xlsxwriter庫版本與示例代碼兼容,因為庫的API可能會隨著版本更新而變化。如果遇到問題,可以查閱庫的官方文檔或GitHub倉庫以獲取最新的使用信息和示例。


本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/14664.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/14664.shtml
英文地址,請注明出處:http://en.pswp.cn/web/14664.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

KMP題解代碼(含講解)

目錄 注意: next數組的變化規律&#xff1a; 初始化&#xff1a; 求next數組部分&#xff1a; KMP部分&#xff1a; AC代碼&#xff1a; 題目鏈接&#xff1a;【模板】KMP - 洛谷 注意: 1、next數組是針對子串的&#xff0c;并未涉及母串&#xff0c;因此求next數組時…

Python中文件操作和異常處理

文章目錄 一、文件操作1.概念2.文件3.二進制 二、基本文件操作三、亂碼產生四、with open() as f五、代碼實現文件復制粘貼六、try ... except ...七、代碼比較 一、文件操作 1.概念 幫助我們把爬蟲抓下來的數據&#xff0c;進行保存。 2.文件 在計算機中&#xff0c;沒有p…

Linux:linux基礎

Linux 一套免費使用和自由傳播的操作系統 linux特點 免費,開源,多用戶(同時允許多用戶操作同一個Linux系統),多任務(同時允許多個任務執行) linux版本 分為內核版和發行版 內核版 由linus torvalds及其團隊進行開發和維護 免費,開源 負責控制硬件 發行版 基于linux內…

Luat學習

萬物互聯的興起 人與人之間的連接已經變得越來越緊密&#xff0c;至少在中國這是一個不爭的事實。 人們的忙碌程度也達到了前所未有的水平&#xff0c;這時候人的通訊能力反而成為了瓶頸&#xff0c;人與外界的信息交換方式無外乎是嘴說、耳朵聽、眼睛看、手指敲、每秒的傳輸速…

根據配置的mode環境顯示不同的index模板

引言&#xff1a;在項目開發中&#xff0c;遇到了開發環境和生產環境使用模板不同的情況&#xff0c;配置如下&#xff1a; 一、vue.config.js const path require(path) function resolve(dir){return path.join(__dirname,dir) } module.exports {chainWebpack: config &g…

力扣226. 翻轉二叉樹(DFS的兩種思路)

Problem: 226. 翻轉二叉樹 文章目錄 題目描述思路復雜度Code 題目描述 思路 涉及二叉樹的遞歸解法時往往需要考慮兩種思路&#xff1a; 1.在遞歸遍歷時執行題目需要的具體要求&#xff1b; 2.將一個大問題分解為多個小子問題 具體到本體&#xff1a; 思路1&#xff1a;遍歷 先…

【源碼分享】簡單的404 HTML頁面示例,該頁面在加載時會等待2秒鐘,然后自動重定向到首頁

展示效果 源碼 html <!DOCTYPE html> <html lang"zh"> <head><meta charset"UTF-8"><title>404 頁面未找到</title><meta http-equiv"refresh" content"2;url/"> <!-- 設置2秒后跳轉到首…

機器學習云環境測試

等待創建完成后&#xff0c;點擊 PyTorch 打開&#xff0c;創建一個全新的 notebook 在 Cell 中輸入如下代碼&#xff0c;并點擊 Run 完成后點擊 New Cell &#xff0c;在 New Cell 中輸入如下代碼 輸入完成后點擊 Run &#xff0c;運行 New Cell 。&#xff08;每個 Cell 代…

1077: 平衡二叉樹的判定

解法&#xff1a; 平衡二叉樹是一種特殊的二叉樹&#xff0c;它滿足以下兩個條件&#xff1a; 左子樹和右子樹的高度差不超過1&#xff08;即&#xff0c;左右子樹高度差的絕對值不超過1&#xff09;。左子樹和右子樹都是平衡二叉樹。 后序遍歷過程中每次判斷左右子樹高度差…

python列表底層原理

Python 列表&#xff08;list&#xff09;是 Python 中非常常用的數據結構之一。它們的底層實現基于動態數組&#xff0c;具體來說&#xff0c;是一個可以動態調整大小的數組。這使得列表在操作和使用上非常靈活。以下是 Python 列表底層實現的主要原理&#xff1a; 動態數組 …

IT廉連看——UniApp——事件綁定

IT廉連看——UniApp——事件綁定 這是我們上節課最終的樣式&#xff1b; 一、現在我有這樣一個需求&#xff0c;當我點擊“生在國旗下&#xff0c;長在春風里”它的顏色由紅色變為藍色&#xff0c;該怎么操作&#xff1f; 這時候我們需要一個事件的綁定&#xff0c;綁定一個單…

使用 Docker 部署 Jenkins 并設置初始管理員密碼

使用 Docker 部署 Jenkins 并設置初始管理員密碼 每一次開始&#xff0c;我都特別的認真與膽怯&#xff0c;是因為我期待結局&#xff0c;也能夠不會那么粗糙&#xff0c;不會讓我失望&#xff0c;所以&#xff0c;就多了些思考&#xff0c;多了些拘束&#xff0c;所以&#xf…

【HCIP學習】STP協議

一、STP協議出現背景&#xff08;Spanning Tree Protocol&#xff0c;生成樹協議&#xff09; 二層環路帶來的問題&#xff1a;廣播風暴&#xff1b; MAC地址表的震蕩&#xff1b; 二、STP定義 stp是二層網絡中用于消除環路的協議&#xff0c;通過阻斷冗余鏈路來消除&#xff…

Flutter 中的 Hero 小部件:全面指南

Flutter 中的 Hero 小部件&#xff1a;全面指南 在 Flutter 中&#xff0c;Hero 動畫是一種流行的動畫效果&#xff0c;用于在不同路由&#xff08;頁面&#xff09;之間傳遞小部件&#xff0c;從而創建平滑的共享元素過渡效果。這種動畫可以增強用戶的視覺體驗&#xff0c;使…

加速度傳感器的沖擊振動的原始特征與解算(部分)

這里是工作中測得的一組數據&#xff0c;設備有多個加速度傳感器通道&#xff0c;我們可以看到沖擊振動發生前后&#xff0c;各個振動傳感器的的反饋以及其他的細化特征&#xff1a; 1.隨機振動&#xff08;加速度傳感器視角&#xff09; 2.沖擊振動&#xff08;加速度&#x…

Android Settings系統屬性讀寫

Settings系統屬性存儲均為xml&#xff0c;分三種&#xff1a; 1.global&#xff1a;所有的偏好設置對系統的所有用戶公開&#xff0c;第三方APP有讀沒有寫的權限&#xff1b; 源碼地址&#xff1a;frameworks/base/core/java/android/provider/Settings.java 對應xml路徑&…

C++ 網絡編程

一、Reactor 網絡編程模型 reactor 是一個事件處理模型。網絡處理:因為用戶層并不知道 IO 什么時候就緒,所以將對 IO 的處理轉化為對事件的處理。網絡模型構成: 非阻塞 IO:操作 IO,如果 IO 未就緒,IO 函數會立刻返回。IO 多路復用:檢測多路 IO 是否就緒。工作流程: 注冊…

【從零開始實現stm32無刷電機FOC】【理論】【1/6 電機旋轉本質】

目錄 電機旋轉需要什么樣的力&#xff1f;怎么產生力矢量&#xff1f;怎么產生任意的線圈磁矢量&#xff1f; 電機旋轉需要什么樣的力&#xff1f; 電機切向存在受力&#xff0c;電機就會旋轉。 進一步查看電機結構&#xff0c;分為轉子和定子&#xff0c;大部分情況下&#…

Spark的概述、核心、組成、運行模式

一、Spark概述 Apache Spark 是一個快速的, 多用途的集群計算系統, 相對于 Hadoop MapReduce 將中間結果保存在磁盤中, Spark 使用了內存保存中間結果, 能在數據尚未寫入硬盤時在內存中進行運算。Spark 是一個計算框架&#xff0c;可以用來代替Hadoop中的MapReduce計算框架。 二…

FIFO-Diffusion,一個無需額外訓練即可生成長視頻的框架。通過確保每個幀引用足夠多的先前幀來生成高質量、一致的長視頻。

簡單來講&#xff0c;FIFO-Diffusion先通過一些模型如VideoCraft2、zeroscope、Opem-Sora Plan等與FIFO-Diffusion的組合生成短視頻&#xff0c;然后取結尾的幀&#xff08;也可以取多幀&#xff09;&#xff0c;再用這一幀的圖片生成另一段短視頻&#xff0c;然后拼接起來。FI…