FromStr

Trait FromStr 

1.0.0 (const: unstable) · Source
pub trait FromStr: Sized {
    type Err;

    // Required method
    fn from_str(s: &str) -> Result<Self, Self::Err>;
}
Expand description

Parse a value from a string

FromStr’s from_str method is often used implicitly, through str’s parse method. See parse’s documentation for examples.

FromStr does not have a lifetime parameter, and so you can only parse types that do not contain a lifetime parameter themselves. In other words, you can parse an i32 with FromStr, but not a &i32. You can parse a struct that contains an i32, but not one that contains an &i32.

§Input format and round-tripping

The input format expected by a type’s FromStr implementation depends on the type. Check the type’s documentation for the input formats it knows how to parse. Note that the input format of a type’s FromStr implementation might not necessarily accept the output format of its Display implementation, and even if it does, the Display implementation may not be lossless so the round-trip may lose information.

However, if a type has a lossless Display implementation whose output is meant to be conveniently machine-parseable and not just meant for human consumption, then the type may wish to accept the same format in FromStr, and document that usage. Having both Display and FromStr implementations where the result of Display cannot be parsed with FromStr may surprise users.

§Examples

Basic implementation of FromStr on an example Point type:

use std::str::FromStr;

#[derive(Debug, PartialEq)]
struct Point {
    x: i32,
    y: i32
}

#[derive(Debug, PartialEq, Eq)]
struct ParsePointError;

impl FromStr for Point {
    type Err = ParsePointError;

    fn from_str(s: &str) -> Result<Self, Self::Err> {
        let (x, y) = s
            .strip_prefix('(')
            .and_then(|s| s.strip_suffix(')'))
            .and_then(|s| s.split_once(','))
            .ok_or(ParsePointError)?;

        let x_fromstr = x.parse::<i32>().map_err(|_| ParsePointError)?;
        let y_fromstr = y.parse::<i32>().map_err(|_| ParsePointError)?;

        Ok(Point { x: x_fromstr, y: y_fromstr })
    }
}

let expected = Ok(Point { x: 1, y: 2 });
// Explicit call
assert_eq!(Point::from_str("(1,2)"), expected);
// Implicit calls, through parse
assert_eq!("(1,2)".parse(), expected);
assert_eq!("(1,2)".parse::<Point>(), expected);
// Invalid input string
assert!(Point::from_str("(1 2)").is_err());

Required Associated Types§

1.0.0 · Source

type Err

The associated error which can be returned from parsing.

Required Methods§

1.0.0 · Source

fn from_str(s: &str) -> Result<Self, Self::Err>

Parses a string s to return a value of this type.

If parsing succeeds, return the value inside Ok, otherwise when the string is ill-formatted return an error specific to the inside Err. The error type is specific to the implementation of the trait.

§Examples

Basic usage with i32, a type that implements FromStr:

use std::str::FromStr;

let s = "5";
let x = i32::from_str(s).unwrap();

assert_eq!(5, x);

Dyn Compatibility§

This trait is not dyn compatible.

In older versions of Rust, dyn compatibility was called "object safety", so this trait is not object safe.

Implementors§

Source§

impl FromStr for AllowedClient

Source§

impl FromStr for Interval

Source§

impl FromStr for ReleaseFidelity

Source§

impl FromStr for WorkerFidelity

1.7.0 · Source§

impl FromStr for IpAddr

Source§

impl FromStr for IpNet

1.0.0 · Source§

impl FromStr for SocketAddr

Source§

impl FromStr for Tz

Source§

impl FromStr for chrono::month::Month

Parsing a str into a Month uses the format %B.

§Example

use chrono::Month;

assert_eq!("January".parse::<Month>(), Ok(Month::January));
assert!("any day".parse::<Month>().is_err());

The parsing is case-insensitive.

assert_eq!("fEbruARy".parse::<Month>(), Ok(Month::February));

Only the shortest form (e.g. jan) and the longest form (e.g. january) is accepted.

assert!("septem".parse::<Month>().is_err());
assert!("Augustin".parse::<Month>().is_err());
Source§

impl FromStr for chrono::weekday::Weekday

Parsing a str into a Weekday uses the format %A.

§Example

use chrono::Weekday;

assert_eq!("Sunday".parse::<Weekday>(), Ok(Weekday::Sun));
assert!("any day".parse::<Weekday>().is_err());

The parsing is case-insensitive.

assert_eq!("mON".parse::<Weekday>(), Ok(Weekday::Mon));

Only the shortest form (e.g. sun) and the longest form (e.g. sunday) is accepted.

assert!("thurs".parse::<Weekday>().is_err());
Source§

impl FromStr for ValueHint

Source§

impl FromStr for ColorChoice

Source§

impl FromStr for Num

Source§

impl FromStr for figment::value::value::Value

Source§

impl FromStr for DNSClass

Source§

impl FromStr for SvcParamKey

Source§

impl FromStr for RecordType

Source§

impl FromStr for InlinableString

Source§

impl FromStr for log::Level

Source§

impl FromStr for log::LevelFilter

Source§

impl FromStr for Network

Source§

impl FromStr for ScopedIp

Source§

impl FromStr for LogLevel

Source§

type Err = &'static str

Source§

impl FromStr for rocket_http::method::Method

Source§

impl FromStr for serde_json::value::Value

Source§

impl FromStr for time::month::Month

Source§

impl FromStr for time::weekday::Weekday

Source§

impl FromStr for toml::value::Value

Source§

impl FromStr for Item

Source§

impl FromStr for toml_edit::value::Value

1.0.0 · Source§

impl FromStr for bool

1.20.0 · Source§

impl FromStr for char

1.0.0 · Source§

impl FromStr for f16

1.0.0 · Source§

impl FromStr for f32

1.0.0 · Source§

impl FromStr for f64

1.0.0 (const: unstable) · Source§

impl FromStr for i8

1.0.0 (const: unstable) · Source§

impl FromStr for i16

1.0.0 (const: unstable) · Source§

impl FromStr for i32

1.0.0 (const: unstable) · Source§

impl FromStr for i64

1.0.0 (const: unstable) · Source§

impl FromStr for i128

1.0.0 (const: unstable) · Source§

impl FromStr for isize

1.0.0 (const: unstable) · Source§

impl FromStr for u8

1.0.0 (const: unstable) · Source§

impl FromStr for u16

1.0.0 (const: unstable) · Source§

impl FromStr for u32

1.0.0 (const: unstable) · Source§

impl FromStr for u64

1.0.0 (const: unstable) · Source§

impl FromStr for u128

1.0.0 (const: unstable) · Source§

impl FromStr for usize

Source§

impl FromStr for CodeLocation

Source§

impl FromStr for ModulePathSelector

Source§

impl FromStr for DnsGlobPattern

Source§

impl FromStr for Namever

Source§

impl FromStr for DbData1

Source§

impl FromStr for DbData2

Source§

impl FromStr for ProjectId

Source§

type Err = <u64 as FromStr>::Err

Source§

impl FromStr for UserId

Source§

type Err = <u64 as FromStr>::Err

Source§

impl FromStr for tag2upload_service_manager::logging::LevelFilter

Source§

impl FromStr for GitObjectId

Source§

impl FromStr for GitObjectIdOrNull

Source§

impl FromStr for HistEntId

Source§

type Err = <i64 as FromStr>::Err

Source§

impl FromStr for Hostname

Source§

impl FromStr for JobId

Source§

type Err = <i64 as FromStr>::Err

Source§

impl FromStr for PackageName

Source§

impl FromStr for PauseId

Source§

type Err = <i64 as FromStr>::Err

Source§

impl FromStr for ProcessingInfo

Source§

impl FromStr for TagObjectData

Source§

impl FromStr for VersionString

Source§

impl FromStr for WorkerId

Source§

impl FromStr for ContentType

Source§

impl FromStr for HtDuration

Source§

impl FromStr for ByteString

1.0.0 · Source§

impl FromStr for String

1.0.0 · Source§

impl FromStr for Ipv4Addr

1.0.0 · Source§

impl FromStr for Ipv6Addr

1.5.0 · Source§

impl FromStr for SocketAddrV4

1.5.0 · Source§

impl FromStr for SocketAddrV6

1.35.0 · Source§

impl FromStr for NonZero<i8>

1.35.0 · Source§

impl FromStr for NonZero<i16>

1.35.0 · Source§

impl FromStr for NonZero<i32>

1.35.0 · Source§

impl FromStr for NonZero<i64>

1.35.0 · Source§

impl FromStr for NonZero<i128>

1.35.0 · Source§

impl FromStr for NonZero<isize>

1.35.0 · Source§

impl FromStr for NonZero<u8>

1.35.0 · Source§

impl FromStr for NonZero<u16>

1.35.0 · Source§

impl FromStr for NonZero<u32>

1.35.0 · Source§

impl FromStr for NonZero<u64>

1.35.0 · Source§

impl FromStr for NonZero<u128>

1.35.0 · Source§

impl FromStr for NonZero<usize>

1.45.0 · Source§

impl FromStr for OsString

Source§

impl FromStr for BString

Source§

impl FromStr for DateTime<FixedOffset>

Accepts a relaxed form of RFC3339. A space or a ‘T’ are accepted as the separator between the date and time parts. Additional spaces are allowed between each component.

All of these examples are equivalent:

"2012-12-12T12:12:12Z".parse::<DateTime<FixedOffset>>()?;
"2012-12-12 12:12:12Z".parse::<DateTime<FixedOffset>>()?;
"2012-  12-12T12:  12:12Z".parse::<DateTime<FixedOffset>>()?;
Source§

impl FromStr for DateTime<Local>

Accepts a relaxed form of RFC3339. A space or a ‘T’ are accepted as the separator between the date and time parts.

All of these examples are equivalent:

"2012-12-12T12:12:12Z".parse::<DateTime<Local>>()?;
"2012-12-12 12:12:12Z".parse::<DateTime<Local>>()?;
"2012-12-12 12:12:12+0000".parse::<DateTime<Local>>()?;
"2012-12-12 12:12:12+00:00".parse::<DateTime<Local>>()?;
Source§

impl FromStr for DateTime<Utc>

Accepts a relaxed form of RFC3339. A space or a ‘T’ are accepted as the separator between the date and time parts.

All of these examples are equivalent:

"2012-12-12T12:12:12Z".parse::<DateTime<Utc>>()?;
"2012-12-12 12:12:12Z".parse::<DateTime<Utc>>()?;
"2012-12-12 12:12:12+0000".parse::<DateTime<Utc>>()?;
"2012-12-12 12:12:12+00:00".parse::<DateTime<Utc>>()?;
Source§

impl FromStr for NaiveDate

Parsing a str into a NaiveDate uses the same format, %Y-%m-%d, as in Debug and Display.

§Example

use chrono::NaiveDate;

let d = NaiveDate::from_ymd_opt(2015, 9, 18).unwrap();
assert_eq!("2015-09-18".parse::<NaiveDate>(), Ok(d));

let d = NaiveDate::from_ymd_opt(12345, 6, 7).unwrap();
assert_eq!("+12345-6-7".parse::<NaiveDate>(), Ok(d));

assert!("foo".parse::<NaiveDate>().is_err());
Source§

impl FromStr for NaiveDateTime

Parsing a str into a NaiveDateTime uses the same format, %Y-%m-%dT%H:%M:%S%.f, as in Debug.

§Example

use chrono::{NaiveDateTime, NaiveDate};

let dt = NaiveDate::from_ymd_opt(2015, 9, 18).unwrap().and_hms_opt(23, 56, 4).unwrap();
assert_eq!("2015-09-18T23:56:04".parse::<NaiveDateTime>(), Ok(dt));

let dt = NaiveDate::from_ymd_opt(12345, 6, 7).unwrap().and_hms_milli_opt(7, 59, 59, 1_500).unwrap(); // leap second
assert_eq!("+12345-6-7T7:59:60.5".parse::<NaiveDateTime>(), Ok(dt));

assert!("foo".parse::<NaiveDateTime>().is_err());
Source§

impl FromStr for NaiveTime

Parsing a str into a NaiveTime uses the same format, %H:%M:%S%.f, as in Debug and Display.

§Example

use chrono::NaiveTime;

let t = NaiveTime::from_hms_opt(23, 56, 4).unwrap();
assert_eq!("23:56:04".parse::<NaiveTime>(), Ok(t));

let t = NaiveTime::from_hms_nano_opt(23, 56, 4, 12_345_678).unwrap();
assert_eq!("23:56:4.012345678".parse::<NaiveTime>(), Ok(t));

let t = NaiveTime::from_hms_nano_opt(23, 59, 59, 1_234_567_890).unwrap(); // leap second
assert_eq!("23:59:60.23456789".parse::<NaiveTime>(), Ok(t));

// Seconds are optional
let t = NaiveTime::from_hms_opt(23, 56, 0).unwrap();
assert_eq!("23:56".parse::<NaiveTime>(), Ok(t));

assert!("foo".parse::<NaiveTime>().is_err());
Source§

impl FromStr for FixedOffset

Parsing a str into a FixedOffset uses the format %z.

Source§

impl FromStr for Cookie<'static>

Source§

impl FromStr for glob::Pattern

Source§

impl FromStr for Glob

Source§

impl FromStr for hickory_proto::rr::domain::name::Name

Source§

impl FromStr for LowerName

Source§

impl FromStr for A

Source§

impl FromStr for AAAA

Source§

impl FromStr for ClientSubnet

Source§

impl FromStr for http::header::name::HeaderName

Source§

impl FromStr for http::header::name::HeaderName

Source§

impl FromStr for http::header::value::HeaderValue

Source§

impl FromStr for http::header::value::HeaderValue

Source§

impl FromStr for http::method::Method

Source§

impl FromStr for http::method::Method

Source§

impl FromStr for http::status::StatusCode

Source§

impl FromStr for http::status::StatusCode

Source§

impl FromStr for http::uri::authority::Authority

Source§

impl FromStr for http::uri::authority::Authority

Source§

impl FromStr for http::uri::path::PathAndQuery

Source§

impl FromStr for http::uri::path::PathAndQuery

Source§

impl FromStr for http::uri::scheme::Scheme

Source§

impl FromStr for http::uri::scheme::Scheme

Source§

impl FromStr for http::uri::Uri

Source§

impl FromStr for http::uri::Uri

Source§

impl FromStr for HttpDate

Source§

impl FromStr for Duration

Source§

impl FromStr for Timestamp

Source§

impl FromStr for hyper_util::client::legacy::connect::dns::Name

Source§

impl FromStr for icu_locale_core::extensions::private::other::Subtag

Source§

impl FromStr for icu_locale_core::extensions::transform::key::Key

Source§

impl FromStr for Attribute

Source§

impl FromStr for icu_locale_core::extensions::unicode::key::Key

Source§

impl FromStr for SubdivisionId

Source§

impl FromStr for SubdivisionSuffix

Source§

impl FromStr for Language

Source§

impl FromStr for Region

Source§

impl FromStr for Script

Source§

impl FromStr for icu_locale_core::subtags::Subtag

Source§

impl FromStr for Variant

Source§

impl FromStr for Ipv4Net

Source§

impl FromStr for Ipv6Net

Source§

impl FromStr for UriTemplateString

Source§

impl FromStr for matchers::Pattern

Source§

impl FromStr for Mime

Source§

impl FromStr for regex::regex::bytes::Regex

Source§

impl FromStr for regex::regex::string::Regex

Source§

impl FromStr for reqwest::dns::resolve::Name

Source§

type Err = InvalidNameError

Source§

impl FromStr for Accept

Source§

impl FromStr for MediaType

Source§

impl FromStr for serde_json::map::Map<String, Value>

Source§

impl FromStr for Number

Source§

impl FromStr for toml::map::Map<String, Value>

Source§

impl FromStr for Datetime

Source§

impl FromStr for Deserializer

Source§

impl FromStr for ValueDeserializer

Source§

impl FromStr for DocumentMut

Source§

impl FromStr for ImDocument<String>

Source§

impl FromStr for InternalString

Source§

impl FromStr for toml_edit::key::Key

Source§

impl FromStr for tracing_core::metadata::Level

Source§

impl FromStr for Directive

Source§

impl FromStr for EnvFilter

Source§

impl FromStr for Targets

Source§

impl FromStr for ByteUnit

Source§

impl FromStr for Braced

Source§

impl FromStr for Hyphenated

Source§

impl FromStr for Simple

Source§

impl FromStr for Urn

Source§

impl FromStr for Uuid

1.85.0 · Source§

impl FromStr for CString

1.32.0 · Source§

impl FromStr for PathBuf

Source§

impl FromStr for Url

Parse a string as an URL, without a base URL or encoding override.

Source§

impl<S> FromStr for RiAbsoluteString<S>
where S: Spec,

Source§

impl<S> FromStr for RiFragmentString<S>
where S: Spec,

Source§

impl<S> FromStr for RiString<S>
where S: Spec,

Source§

impl<S> FromStr for RiQueryString<S>
where S: Spec,

Source§

impl<S> FromStr for RiReferenceString<S>
where S: Spec,

Source§

impl<S> FromStr for RiRelativeString<S>
where S: Spec,

Source§

impl<T> FromStr for MaybeOwned<'_, T>
where T: FromStr,

Source§

type Err = <T as FromStr>::Err

Source§

impl<T> FromStr for MaybeOwnedMut<'_, T>
where T: FromStr,

Source§

type Err = <T as FromStr>::Err

Source§

impl<V: SuitableForNoneIsEmpty> FromStr for NoneIsEmpty<V>

Source§

impl<const MIN: i8, const MAX: i8> FromStr for RangedI8<MIN, MAX>

Source§

impl<const MIN: i16, const MAX: i16> FromStr for RangedI16<MIN, MAX>

Source§

impl<const MIN: i32, const MAX: i32> FromStr for RangedI32<MIN, MAX>

Source§

impl<const MIN: i64, const MAX: i64> FromStr for RangedI64<MIN, MAX>

Source§

impl<const MIN: i128, const MAX: i128> FromStr for RangedI128<MIN, MAX>

Source§

impl<const MIN: isize, const MAX: isize> FromStr for RangedIsize<MIN, MAX>

Source§

impl<const MIN: u8, const MAX: u8> FromStr for RangedU8<MIN, MAX>

Source§

impl<const MIN: u16, const MAX: u16> FromStr for RangedU16<MIN, MAX>

Source§

impl<const MIN: u32, const MAX: u32> FromStr for RangedU32<MIN, MAX>

Source§

impl<const MIN: u64, const MAX: u64> FromStr for RangedU64<MIN, MAX>

Source§

impl<const MIN: u128, const MAX: u128> FromStr for RangedU128<MIN, MAX>

Source§

impl<const MIN: usize, const MAX: usize> FromStr for RangedUsize<MIN, MAX>

Source§

impl<const N: usize> FromStr for TinyAsciiStr<N>