// include the latest version of the regex crate in your Cargo.toml
extern crate regex;
use regex::Regex;
fn main() {
let regex = Regex::new(r#"<img (?:.*?class=['"](?!google[ '"])(?![^'"]* google['"]).+?['"]|(?!class=['"]))\s*[\/]?>"#).unwrap();
let string = "<img src=\"https://google.com/animage.jpg\" class=\"google\">
<img src=\"https://yahoo.com/animage.jpg\">
<img src=\"https://google.com/animage.jpg\" class=\"google\">
<img src=\"https://yahoo.com/animage.jpg\" class=\"azerty\">
<img src=\"https://yahoo.com/animage.jpg\" class=\"not-a-google\">
<img src=\"https://yahoo.com/animage.jpg\" class=\"azerty still-not-a-google\">
<img src=\"https://yahoo.com/animage.jpg\" class=\"google-i-am-not\">
<img src=\"https://yahoo.com/animage.jpg\" class=\"azerty still-not-a-google\" rel=\"google\">
<img src=\"https://yahoo.com/animage.jpg\" class=\"azerty still-not-a-google\" rel=\"google\"/>
<img src=\"https://yahoo.com/animage.jpg\" class=\"azerty still-not-a-google\" rel=\"google\" />
<img src=\"https://yahoo.com/animage.jpg\" class=\"\" rel=\"google\" >
<img src=\"https://yahoo.com/animage.jpg\" class=\"totally-a google\" rel=\"google\" />
<img src=\"https://yahoo.com/animage.jpg\" class='i-love-myhtml-with-single-quotes google' rel=\"google\" />
<img src=\"https://yahoo.com/animage.jpg\" class='i-love-myhtml-with-single-quotes not-a-google' rel=\"google\" />";
// result will be an iterator over tuples containing the start and end indices for each match in the string
let result = regex.captures_iter(string);
for mat in result {
println!("{:?}", mat);
}
}
Please keep in mind that these code samples are automatically generated and are not guaranteed to work. If you find any syntax errors, feel free to submit a bug report. For a full regex reference for Rust, please visit: https://docs.rs/regex/latest/regex/