格式化
正则表达式匹配使用贪婪算法,即算法可能多的匹配字符。
%[ ] 一个字符集。
“%ns”,n为整数,读入的字符串最长不超过n,然后在末尾补’\0’。
%nf 读入的浮点数最多有n位整数,位数多于n,会截断。
“%n[a-z]” 读入最多n个字符,如果遇到非a-z的字符,停止。
“%[^=]” 读入任意多的字符,直到遇到"=“停止。
“%n[^=]” 读入”="号前的至多n 个字符。
"*"表示该输入项读入后不赋予任何变量,即跳过该输入值。
%*是指忽略匹配的字符,比如“%*[a-z]”,忽略匹配[a-z]的字符。可以把%*看作%的兄弟,只是%是读入到变量,%*是跳过。
比如%[0-9]表示只读入’0’到’9’之间的字符,遇到非数字就会停止,%[a-zA-Z]表示只读入字母,遇到非字母就停止。
'-'是范围连接符,也可以直接列出你需要读入的字符。
例如
- %[^]]表示不断输入遇到 ] 为止。
- %[^\n]%*c遇到换行为止 %*c是吸收了换行符。
- scanf(“%[^0-9]%d”,str,&num); 表示遇到非数字字符为止,然后num保存数字。
- %[a*_]遇到a,*,_停止输入
- scanf(“%*[^:]:%[^@]”,str);
//分析:首先,%*[^:]忽略掉开头字符串,直到:,然后读取,以@为终止符。
//注意:中间有个: 是为了匹配后继续读取。