实际情况:其他部门给的excel表,需要去更新多余字段数据,或插入数据。
1.插入还好,用数据库工具,可选定excel字段对应数据库中目标表字段。
2.但是之前插入数据后,需要更新字段。
- 直接在excel中操作!巧用excel的函数 &
="insert into test(id,name) values('"&A1&"','"&B1&"');"
因为test表中 name 为字符串,对应excel B列; 所以 ' "&B1&" '
注意:空格是为了方便看清 双引号内-表达式,单引号-表明里面为字符串形式!- 在文本中操作时 $
之前不明白 (.*)为什么匹配1 后面(.*)的又匹配 er
()——标记一个子表达式的开始和结束位置。子表达式可以获取供以后$1,$2使用
.除\n外任意字符,*匹配0次或多次,改为 (.+)也能匹配
特殊字符:
特别字符 描述 $ 匹配输入字符串的结尾位置。如果设置了 RegExp 对象的 Multiline 属性,则 $ 也匹配 '\n' 或 '\r'。要匹配 $ 字符本身,请使用 \$。 ( ...) 标记一个子表达式的开始和结束位置。子表达式可以获取供以后使用。要匹配这些字符,请使用 \( 和 \)。(b|cd)3 可匹配 b3 或 cd3 * 匹配前面的子表达式/左边符号 0 或 多次。要匹配 * 字符,请使用 \*。 + 匹配前面的子表达/左边符号 式 1 或 多次。要匹配 + 字符,请使用 \+。 . 匹配除换行符 \n 之外的任何单字符。要匹配 . ,请使用 \. 。 匹配一次 [] 字符集合,用于精确匹配。[0-9a-zA-Z_]匹配字母,数字或下划线 。[^0-9]匹配一个非数字的字符 ? 匹配前面的子表达式0 或 1次,或指明一个非贪婪限定符。要匹配 ? 字符,请使用 \?。 \ 转义字符。例如, 'n' 匹配字符 'n'。'\n' 匹配换行符。序列 '\\' 匹配 "\",而 '\(' 则匹配 "("。 ^ 匹配输入字符串的开始位置,除非在方括号表达式中使用,当该符号在方括号表达式中使用时,表示不接受该方括号表达式中的字符集合。要匹配 ^ 字符本身,请使用 \^。 {m} ab{2} ,匹配abb 。bc{3}d,匹配bcccd 匹配左边符号次数m次 {m,} 匹配最少m次,最多无限制 {,m} 最少0次,最多m次 | 或匹配。Fa123和Df123 可写为Fa|Df 要匹配 |,请使用 \|。
修饰符
修饰符 | 含义 | 描述 |
---|---|---|
i | ignore - 不区分大小写 | 将匹配设置为不区分大小写,搜索时不区分大小写: A 和 a 没有区别。 |
g | global - 全局匹配 | 查找所有的匹配项。 |
m | multi line - 多行匹配 | 使边界字符 ^ 和 $ 匹配每一行的开头和结尾,记住是多行,而不是整个字符串的开头和结尾。 |
s | 特殊字符圆点 . 中包含换行符 \n | 默认情况下的圆点 . 是匹配除换行符 \n 之外的任何字符,加上 s 修饰符之后, . 中包含换行符 \n。 |
// 不区分大小写匹配
const regex1 = /hello/i;
console.log(regex1.test('Hello')); // 输出 true// 全局匹配
const regex2 = /test/g;
console.log('test test test'.match(regex2)); // 输出 ["test", "test", "test"]
==========================import java.util.regex.*;
public class Main {
public static void main(String[] args) {
// 全局匹配
Pattern pattern = Pattern.compile("test", Pattern.MULTILINE);
Matcher matcher = pattern.matcher("test test test");
while (matcher.find()) {
System.out.println(matcher.group());
}
}
}