亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Rust讀取配置文件的實現(xiàn)

 更新時間:2024年03月14日 11:20:53   作者:一碗情深  
本文主要介紹了Rust讀取配置文件的實現(xiàn),主要讀取Cargo.toml文件,讀取.env文件和讀取自定義toml文件這三種,具有一定的參考價值,感興趣的可以了解一下

1. 讀取Cargo.toml文件

Cargo.toml 文件配置如下:

[package] 
name = "axum" 
version = "0.1.0" 
authors = ["chh <1400152400@qq.com>"] 
edition = "2021"

main.rs

fn main() {
    let name = env!("CARGO_PKG_NAME");
    let version = env!("CARGO_PKG_VERSION");
    let author = env!("CARGO_PKG_AUTHORS");
    println!("{} {} {}", &name, &version, &author);
}

運行結果:

axum 0.1.0 chh <1400152400@qq.com>

2. 讀取.env文件

項目根目錄新建 .env 文件,寫入如下代碼:

DATABASE_URL=mysql://postgres:123456@localhost:3306/test

Cargo.toml 文件配置導入以下第三方庫:

[dependencies]
dotenv = "0.15.0"

main.rs

use dotenv::dotenv;
use std::env;

fn main() {
    // 在訪問環(huán)境變量之前檢查一下,防止因讀取環(huán)境變量失敗導致程序恐慌。
    // 先把 dotenv 導入,然后在程序開始的地方執(zhí)行 dotenv() 函數(shù)即可,這就會從當前目錄或父目錄中的 .env 文件中加載環(huán)境變量。
    // 如果你想指定其它路徑,可以使用 crate 中提供的 from_filename 或 from_path 這兩個函數(shù)。
    // 好,那么調(diào)用 dotenv() 之后為什么還要調(diào)用 ok() 方法?
    // 首先,dotenv() 返回的是 Result<PathBuf> 類型,如果返回值不使用的話,就會發(fā)出一個警告:
    // 調(diào)用 ok() 之后,會把 Result 轉(zhuǎn)化為 Option,而 Option 就不會產(chǎn)生未使用 Result 的警告了。
    // 那么,為什么不使用 unwrap()?
    // 因為在生產(chǎn)環(huán)境中,你不會使用 .env 這個文件,你應該使用真實的環(huán)境變量,這時 dotenv() 函數(shù)就會加載失敗,如果使用 unwrap(),那么你的程序就會停止運行。
    // 所以這里使用 ok() 的目的就是當加載 dotenv 環(huán)境文件失敗的時候可以忽略錯誤。
    dotenv().ok();

    let database_url = env::var("DATABASE_URL").expect("DATABASE_URL 沒有在 .env 文件里設置");

    print!("{:?}", database_url);
}

運行結果:

"mysql://postgres:123456@localhost:3306/test"

3. 讀取自定義toml文件

項目根目錄新建 config.toml 文件,寫入如下代碼:

[database]
url = "postgres://postgres:123456@localhost/test"

[log]
debug = true
debug_sql = false
log_root = "/tmp"

Cargo.toml 文件配置導入以下第三方庫:

[dependencies]
config = "0.13.1"
toml = "0.5.9"
lazy_static = "1.4"
serde = "1.0"
serde_derive = "1.0"

新建 settings.rs ,寫入如下代碼:

use std::{fs::File, io::Read};
use lazy_static::lazy_static;
use serde::Deserialize;

#[derive(Debug, Deserialize)]
pub struct Database {
    pub url: String,
}

#[derive(Debug, Deserialize)]
pub struct Log {
    pub debug: bool,
    pub debug_sql: bool,
    pub log_root: String,
}

#[derive(Debug, Deserialize)]
pub struct Settings {
    pub database: Database,
    pub log: Log,
}

impl Default for Settings {
    fn default() -> Self {
        let file_path = "config.toml";
        let mut file = match File::open(file_path) {
            Ok(f) => f,
            Err(e) => panic!("no such file {} exception:{}", file_path, e)
        };
        let mut str_val = String::new();
        match file.read_to_string(&mut str_val) {
            Ok(s) => s,
            Err(e) => panic!("Error Reading file: {}", e)
        };
        toml::from_str(&str_val).expect("Parsing the configuration file failed");
    }
}

impl Settings {
    pub fn get<'a>() -> &'a Self {
        // 給靜態(tài)變量延遲賦值的宏
        lazy_static! {
            static ref CACHE: Settings = Settings::default();
        }
        &CACHE
    }
}

main.rs 代碼如下:

use crate::settings::Settings;

mod settings;

fn main() {
    let setting = Settings::get();
    println!("{:?}", setting.database.url);
    println!("{:?}", setting.log);
}

運行結果:

"postgres://postgres:123456@localhost/test"
Log { debug: true, debug_sql: false, log_root: "/tmp" }

到此這篇關于Rust讀取配置文件的實現(xiàn)的文章就介紹到這了,更多相關Rust 讀取配置文件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:

相關文章

  • Rust中的Iterator和IntoIterator介紹及應用小結

    Rust中的Iterator和IntoIterator介紹及應用小結

    Iterator即迭代器,它可以用于對數(shù)據(jù)結構進行迭代,被迭代的數(shù)據(jù)結構是可迭代的(iterable),所謂的可迭代就是這個數(shù)據(jù)結構有返回迭代器的方法,這篇文章主要介紹了Rust中的Iterator和IntoIterator介紹及應用,需要的朋友可以參考下
    2023-07-07
  • Rust?Atomics?and?Locks?源碼解讀

    Rust?Atomics?and?Locks?源碼解讀

    這篇文章主要為大家介紹了Rust?Atomics?and?Locks?源碼解讀,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-02-02
  • 深入了解Rust中的枚舉和模式匹配

    深入了解Rust中的枚舉和模式匹配

    這篇文章主要為大家詳細介紹了Rust中的枚舉和模式匹配的相關知識,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學習一下
    2024-01-01
  • Tauri?打開本地文件踩坑分析解決

    Tauri?打開本地文件踩坑分析解決

    這篇文章主要為大家介紹了Tauri?打開本地文件踩坑分析解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-04-04
  • rust生命周期詳解

    rust生命周期詳解

    生命周期是rust中用來規(guī)定引用的有效作用域,在大多數(shù)時候,無需手動聲明,因為編譯器能夠自動推導,這篇文章主要介紹了rust生命周期相關知識,需要的朋友可以參考下
    2023-03-03
  • Rust?Atomics?and?Locks內(nèi)存序Memory?Ordering詳解

    Rust?Atomics?and?Locks內(nèi)存序Memory?Ordering詳解

    這篇文章主要為大家介紹了Rust?Atomics?and?Locks內(nèi)存序Memory?Ordering詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-02-02
  • rust的nutyp驗證和validator驗證數(shù)據(jù)的方法示例詳解

    rust的nutyp驗證和validator驗證數(shù)據(jù)的方法示例詳解

    本文介紹了在Rust語言中,如何使用nuType和validator兩種工具來對Cargo.toml和modules.rs文件進行驗證,通過具體的代碼示例和操作步驟,詳細解釋了驗證過程和相關配置,幫助讀者更好地理解和掌握使用這兩種驗證工具的方法,更多Rust相關技術資訊,可繼續(xù)關注腳本之家
    2024-09-09
  • Rust在寫庫時實現(xiàn)緩存的操作方法

    Rust在寫庫時實現(xiàn)緩存的操作方法

    Moka是一個用于Rust的高性能緩存庫,它提供了多種類型的緩存數(shù)據(jù)結構,包括哈希表、LRU(最近最少使用)緩存和?支持TTL(生存時間)緩存,這篇文章給大家介紹Rust在寫庫時實現(xiàn)緩存的相關知識,感興趣的朋友一起看看吧
    2024-01-01
  • Rust 中判斷兩個 HashMap 是否相等

    Rust 中判斷兩個 HashMap 是否相等

    在Rust標準庫中,HashMap 實現(xiàn)了 PartialEq 和 Eq trait,但是這些trait的實現(xiàn)是基于嚴格的結構相等性,包括元素的順序,這篇文章主要介紹了Rust 中判斷兩個 HashMap 是否相等,需要的朋友可以參考下
    2024-04-04
  • Rust 累計時間長度的操作方法

    Rust 累計時間長度的操作方法

    在Rust中,如果你想要記錄累計時間,通常可以使用標準庫中的std::time::Duration類型,這篇文章主要介紹了Rust如何累計時間長度,需要的朋友可以參考下
    2024-05-05

最新評論