Skip to content

Convenient library for extracting images of cute (or not so cute) characters from websites.

License

Notifications You must be signed in to change notification settings

TOwInOK/anime-grubber

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

24 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

anime-grubber

Crates.io Documentation License удобная библиотека для извлечения изображений милых (или не совсем) персонажей с веб-сайтов.

Возможности

  • Извлечение изображений и GIF с аниме-сайтов и других ресурсов.
  • Поддержка работы с различными категориями медиа, включая SFW (Safe for Work) и NSFW (Not Safe for Work).
  • Лёгкая интеграция с асинхронными приложениями на базе Tokio.
  • Встроенные агенты для работы с популярными API (например, Waifu.pics).
  • Логирование событий для отладки и отслеживания процесса загрузки медиа.

Агенты

Установка

Пропишите в консоль:

cargo add anime-grubber

или

Добавьте anime-grubber в ваш Cargo.toml:

[dependencies]
anime-grubber = "0"

Использование

use anime_grubber::agents::waifu_pics::{Waifu, Categories, SFW};

#[tokio::main]
async fn main() -> anyhow::Result<()> {
    let instance = Waifu::new(Categories::SFW(SFW::Dance));
    let image = instance.get().await?;
    println!("Fetched image URL: {}", image);
    Ok(())
}

Примеры использования

Извлечение одного изображения

Этот пример показывает, как можно получить одно изображение из категории SFW::Dance:

use anime_grubber::agents::waifu_pics::{Waifu, Categories, SFW};
use tracing::info;

#[tokio::main]
async fn main() -> anyhow::Result<()> {
    let instance = Waifu::new(Categories::SFW(SFW::Dance));
    let image = instance.get().await?;
    info!("Fetched image URL: {}", image);
    Ok(())
}

Извлечение нескольких изображений

Получение сразу нескольких изображений из той же категории:

use anime_grubber::agents::waifu_pics::{Waifu, Categories, SFW};
use tracing::info;

#[tokio::main]
async fn main() -> anyhow::Result<()> {
    let instance = Waifu::new(Categories::SFW(SFW::Dance));
    let images = instance.get_many().await?;
    assert_eq!(images.len(), 30);
    info!("{:#?}", images);
    Ok(())
}

Логирование

Для удобства отладки используется библиотека tracing. Пример настройки глобального логгера можно увидеть в тестах.

use tracing_subscriber::FmtSubscriber;

tracing::subscriber::set_global_default(
    FmtSubscriber::builder()
        .with_max_level(tracing::Level::DEBUG) //  or you can use INFO .with_max_level(tracing::Level::INFO)
        .pretty()
        .without_time()
        .finish(),
).expect("Failed to set global default subscriber");

Тестирование

Библиотека содержит примеры тестов, которые можно найти в модуле Tests:

Лицензия

Этот проект распространяется под лицензией MIT. Подробности см. в файле LICENSE.

About

Convenient library for extracting images of cute (or not so cute) characters from websites.

Topics

Resources

License

Stars

Watchers

Forks

Languages