us_address_parser

Crates.ious_address_parser
lib.rsus_address_parser
version0.1.4
sourcesrc
created_at2024-09-11 16:42:03.660757
updated_at2024-09-12 19:09:13.75953
descriptionA Rust crate that parses U.S. street addresses.
homepagehttps://github.com/Cosiamo/us_address_parser
repositoryhttps://github.com/Cosiamo/us_address_parser
max_upload_size
id1372080
size50,860
Joshua Becnel (Cosiamo)

documentation

README

US Address Parser

A Rust Crate that parses United States street addresses.

How To Use

To get started, simply import the AddressParsing trait to your file, and add the parse_addr() method to the String or &str you want to parse. It will return the Address struct, which contains; the street number, street name, street type, unit type, and unit number. Each of these fields are Option<String>.

use us_address_parser::AddressParsing;

fn main() {
    let addresses: Vec<&str> = vec![
        "123 Main Ave",
        "456 Maple Blvd Apt 122",
        "789 3rd St Lot B"
    ];

    for addr in addresses {
        println!("{}", &addr);

        let address = addr.parse_addr();
        
        println!("Street_no:{:?}, dir:{:?}, street_name:{:?}, street_type:{:?}, unit_type:{:?}, unit_no:{:?}\n==========", 
            address.street_no, address.direction, address.street_name,
            address.street_type, address.unit_type, address.unit_no
        );
    }
}
Result:
123 Main Ave
Street_no:Some("123"), dir:None, street_name:Some("MAIN"), street_type:Some("AVE"), unit_type:None, unit_no:None
==========
456 Maple Blvd Apt 122
Street_no:Some("456"), dir:None, street_name:Some("MAPLE"), street_type:Some("BLVD"), unit_type:Some("APT"), unit_no:Some("122")
==========
789 3rd St Lot B
Street_no:Some("789"), dir:None, street_name:Some("3RD"), street_type:Some("ST"), unit_type:Some("LOT"), unit_no:Some("B")
==========

Implementing A Custom Type

The [AddressParsing] trait is already implemented for strings,

struct CustomerInfo {
    id: usize,
    customer_name: String,
    customer_address: String
}

impl AddressParsing for CustomerInfo {
    fn parse_addr(&self) -> Address {
        let address = self.customer_address;
        us_address_parser::string_to_address(address)
    }
}

The string_to_address() function does what it's name implies, converts a String to an Address.

Commit count: 0

cargo fmt