1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
use std::collections::{BTreeMap, HashSet, LinkedList};
use std::io::Read;
use rbson::Bson;
pub const LOG_SPACE: &'static str = " ";
pub fn find_convert_string(arg: &str) -> LinkedList<(String, String)> {
let mut list = LinkedList::new();
let mut cache = HashSet::new();
let chars: Vec<u8> = arg.bytes().collect();
let mut item = String::with_capacity(arg.len());
let mut index: i32 = -1;
for v in &chars {
index = index + 1;
if !item.is_empty() {
item.push(*v as char);
if *v == '}' as u8 {
if cache.get(&item).is_some() {
item.clear();
continue;
}
let key = item[2..item.len() - 1].to_string();
cache.insert(item.clone());
list.push_back((key, item.clone()));
item.clear();
}
continue;
}
if (*v == '#' as u8 || *v == '$' as u8)
&& chars.get(index as usize + 1).eq(&Some(&('{' as u8)))
{
item.push(*v as char);
}
}
return list;
}
pub fn count_string_num(s: &String, c: char) -> usize {
let cs = s.chars();
let mut num = 0;
for x in cs {
if x == c {
num += 1;
}
}
return num;
}
pub fn to_snake_name(name: &str) -> String {
let chs = name.chars();
let mut new_name = String::new();
let mut index = 0;
let chs_len = name.len();
for x in chs {
if x.is_uppercase() {
if index != 0 && (index + 1) != chs_len {
new_name.push_str("_");
}
new_name.push_str(x.to_lowercase().to_string().as_str());
} else {
new_name.push(x);
}
index += 1;
}
return new_name;
}
pub fn un_packing_string(column: &str) -> &str {
if column.len() >= 2 {
if column.starts_with("'") && column.ends_with("'") {
return &column[1..column.len() - 1];
}
if column.starts_with("`") && column.ends_with("`") {
return &column[1..column.len() - 1];
}
if column.starts_with("\"") && column.ends_with("\"") {
return &column[1..column.len() - 1];
}
}
return column;
}
pub fn find_format_string(arg: &str) -> LinkedList<(String, String)> {
let mut list = LinkedList::new();
let chars: Vec<u8> = arg.bytes().collect();
let mut item = String::with_capacity(arg.len());
let mut index: i32 = -1;
for v in &chars {
index = index + 1;
if !item.is_empty() {
item.push(*v as char);
if *v == '}' as u8 {
let key = item[1..item.len() - 1].to_string();
list.push_back((key, item.clone()));
item.clear();
}
continue;
}
if *v == '{' as u8 {
item.push(*v as char);
}
}
return list;
}
#[test]
fn test_find_formats() {
println!("{:?}", find_format_string("1111{}222{1}2"));
}