The purpose of this crate is to more easily work with Google Product Categories / Taxonomy.
This is provided via the google_taxonomy::ProductCategory
struct which contains all categories that exist as of 2021-08-13.
The ProductCategory contains each product category as an associated constant. They are translated from the taxonomy-with-ids.en-US.txt file as follows:
- The leading ID is removed (and can be obtained using the
id
method). - The immediately following characters
-
are removed - All occurrences of
&
are replaced withAnd
- Finally, all non-alphanumeric ascii characters are removed
For example 1604 - Apparel & Accessories > Clothing
becomes ProductCategory::ApparelAndAccessoriesClothing
.
Each constant takes up 2 bytes of memory.
use std::convert::TryInto;
use google_taxonomy::ProductCategory;
let cat: ProductCategory = 3237.try_into().unwrap();
assert_eq!(cat, ProductCategory::AnimalsAndPetSuppliesLiveAnimals);
use google_taxonomy::ProductCategory;
assert_eq!(ProductCategory::AnimalsAndPetSuppliesLiveAnimals.id(), 3237);
use google_taxonomy::ProductCategory;
assert_eq!(ProductCategory::AnimalsAndPetSuppliesLiveAnimals.to_string(), "Animals & Pet Supplies > Live Animals");
#[cfg(feature = "serde")]
{
use serde::{Deserialize, Serialize};
use google_taxonomy::ProductCategory;
#[derive(Deserialize, Serialize, Debug, PartialEq)]
struct Product {
category: ProductCategory,
}
let serialized = r#"{"category":"Animals & Pet Supplies"}"#;
// Deserialize, e.g. with serde_json
let deserialized: Product = serde_json::from_str(&serialized).unwrap();
assert_eq!(deserialized, Product { category: ProductCategory::AnimalsAndPetSupplies });
// And back to its original serialized form again...
assert_eq!(serde_json::to_string(&deserialized).unwrap(), serialized);
}