应用正则表达式表述式(regex

摘要: 应用正则表达式表述式(regex_replace)仿真模拟载入INI文档|频道:正则表达式表述式|点一下: 次空话很少讲过,立即给大伙儿贴编码了,实际编码以下所显示:#include "stdio.h" #include sstre...

应用正则表达式表述式(regex_replace)仿真模拟载入INI文档 |频道:正则表达式表述式|点一下: 次

空话很少讲过,立即给大伙儿贴编码了,实际编码以下所显示:

#include "stdio.h" #include sstream #include iostream #include fstream #include regex using namespace std; void Trim(char * str); void lTrim(char * str); void rTrim(char * str); // 检测sscanf 和 正则表达式表述式 // sscanf出示的这一拓展作用实际上其实不能真实称之为正则表达式表述式,由于他的撰写還是离不了% // []表明标识符范畴,{}表明反复频次,^表明取非,*表明绕过。因此上边这一url的分析能够写出下边这一模样: //char url[] = "dv://192.168.1.253:65001/1/1" //sscanf(url, "%[^://]%*c%*c%*c%[^:]%*c%d%*c%d%*c%d", protocol, ip, port, chn, type); //表述一下 //先获得一个最多的标识符串,但不包含字串 ://,因此protocol="dv\0"; //随后绕过三字符,(%*c)实际上便是绕过 :// // 然后取一字符串不包含标识符串 : ,因此ip = 192.168.1.253,这儿简单化解决了,IP就当字符串来弄,并且不做查验 // 随后绕过冒号取端口号到port,再绕过 / 取安全通道号到chn,再绕过 / 取视频比特率种类到type。 // c語言完成上例 void test1() char url[] = "dv://192.168.1.253:65001/1/1"; char protocol[10]; char ip[17]; int port; int chn; int type; sscanf(url, "%[^://]%*c%*c%*c%[^:]%*c%d%*c%d%*c%d", protocol, ip, port, chn, type); printf("%s, %s, %d, %d, %d\n", protocol, ip, port, chn, type); // 载入ini里某行标识符串, 获得: hello world! // 一切正常串1: -claim="hello world!" // 一切正常串2: claim = "hello world!" // 一切正常串3: claim = " hello world!" // 一切正常串4: claim_ = hello world! // 影响串1: cl-aim = \"hello world!" // 影响串2: clai3m = "hello world!\" // 影响串3: cla_im = \\"hello world!\" // 影响串4: claim ='"hello world!\" // 影响串5: claim= @"\nhello world!" // 影响串6: claim=L"hello world!" // 未解决1: claim[1] = 1 // 未解决1: claim[2] = 1 void test2() char line[1000] = { 0 }; char val[1000] = { 0 }; char key[1000] = { 0 }; FILE *fp = fopen("1.txt", "r"); if (NULL == fp) printf("failed to open 1.txt\n"); return ; while (!feof(fp)) memset(line, 0, sizeof(line)); fgets(line, sizeof(line) - 1, fp); // 包括了每列的\n printf("%s", line); Trim(line); // 获取百分号以前的內容 memset(key, 0, sizeof(key)); // sscanf应用的format并不是正则表达式表述式,不可以用 \\s 表明各种各样空白页符,即空格符或\t,\n,\r,\f sscanf(line, "%[^ \t\n\r\f=]", key); //sscanf(line, "%*[^a-zA-Z0-9_-]%[^ \t\n\r\f=]", key); printf(" key: [%s]\n", key); // 获取百分号以后的內容 memset(val, 0, sizeof(val)); sscanf(line, "%*[^=]%*c%[^\n]", val); // 不包括了每列的换行符 Trim(val); printf(" val: [%s]\n", val); // 除去两侧双引号 // ... // 插进map // map[key]=value; // string 转 其他种类 // atoi, atol, atof printf("\n"); fclose(fp); // 上例的C++完成 template class T1, class T2 inline T1 parseTo(const T2 t) static stringstream sstream; T1 r; sstream t; sstream r; sstream.clear(); return r; void test3() char val[1000] = { 0 }; char key[1000] = { 0 }; ifstream fin("1.txt"); string line; if (fin) while (getline(fin, line)) // line中不包含每列的换行符 cout line endl; /// 获取百分号以前的內容 // 第一组()表明随意个空格符标识符,第二组()表明英语单词(可带_或-), // 第三组()表明一个之上的空格符标识符(或=),最终以随意标识符串末尾 regex reg("^([\\s]*)([\\w\\-\\_]+)([\\s=]+).*$"); // 取第二组替代原串 string key = regex_replace(line, reg, "$2"); cout " key: {" key "}" endl; /// 获取百分号以后的內容 // 第一组()表明随意个空格符标识符,第二组()表明英语单词(可带_或-), // 第三组()表明一个之上的空格符标识符(或=),第四组()表明随意字符, // 第5组()表明以随意个空格符标识符(或回车键换行符)末尾。 reg = regex("^([\\s]*)([\\w\\-\\_]+)([\\s=]+)(.*)([\\s\\r\\n]*)$"); // 取第四组替代原串 string val = regex_replace(line, reg, "$4"); cout " val: {" val "}" endl; // 除去两侧双引号 // ... // 插进map // map[key]=value; // string 转 其他种类 // int i = parseTo int ("123"); // float f = parseTo float ("1.23"); // string str = parseTo string (123); else // 沒有该文档 cout "no such file" endl; void main() //test1(); test2(); test3(); void lTrim(char * str) int i, len; len = strlen(str); for (i = 0; i i++) if (str[i] != ' ' str[i] != '\t' str[i] != '\n' str[i] != '\r' str[i] != '\f') break; memmove(str, str + i, len - i + 1); return; void rTrim(char * str) int i, len; len = strlen(str); for (i = len - 1; i i--) if ((str[i] != ' ') (str[i] != 0x0a) (str[i] != 0x0d) (str[i] != '\t') (str[i] != '\f')) break; str[i + 1] = 0; return; void Trim(char * str) int i, len; //先除去左侧的空格符 len = strlen(str); for (i = 0; i i++) if (str[i] != ' ' str[i] != '\t' str[i] != '\n' str[i] != '\r' str[i] != '\f') break; memmove(str, str + i, len - i + 1); //再除去右侧的空格符 len = strlen(str); for (i = len - 1; i i--) if (str[i] != ' ' str[i] != '\t' str[i] != '\n' str[i] != '\r' str[i] != '\f') break; str[i + 1] = 0; return; void Trim(char * str) lTrim(str); rTrim(str);


共2页: 上一页12下一页


联系我们

全国服务热线:4000-399-000 公司邮箱:343111187@qq.com

  工作日 9:00-18:00

关注我们

官网公众号

官网公众号

Copyright?2020 广州凡科互联网科技股份有限公司 版权所有 粤ICP备10235580号 客服热线 18720358503

技术支持:自助建站