主頁(yè) > 知識(shí)庫(kù) > 使用正則表達(dá)式(regex_replace)模擬讀取INI文件

使用正則表達(dá)式(regex_replace)模擬讀取INI文件

熱門(mén)標(biāo)簽:服務(wù)器配置 阿里云 Mysql連接數(shù)設(shè)置 銀行業(yè)務(wù) Linux服務(wù)器 科大訊飛語(yǔ)音識(shí)別系統(tǒng) 電子圍欄 團(tuán)購(gòu)網(wǎng)站

廢話不多說(shuō)了,直接給大家貼代碼了,具體代碼如下所示:

#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); 
// 測(cè)試sscanf 和 正則表達(dá)式 
// sscanf提供的這個(gè)擴(kuò)展功能其實(shí)并不能真正稱(chēng)為正則表達(dá)式,因?yàn)樗臅?shū)寫(xiě)還是離不開(kāi)% 
// []表示字符范圍,{}表示重復(fù)次數(shù),^表示取非,*表示跳過(guò)。所以上面這個(gè)url的解析可以寫(xiě)成下面這個(gè)樣子: 
// 
//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); 
// 
//解釋一下 
//先取得一個(gè)最長(zhǎng)的字符串,但不包括字串 ://,于是protocol="dv\0"; 
//然后跳過(guò)三個(gè)字符,(%*c)其實(shí)就是跳過(guò) :// 
// 接著取一個(gè)字符串不包括字符串 : ,于是ip = 192.168.1.253,這里簡(jiǎn)化處理了,IP就當(dāng)個(gè)字符串來(lái)弄,而且不做檢查 
// 然后跳過(guò)冒號(hào)取端口到port,再跳過(guò) / 取通道號(hào)到chn,再跳過(guò) / 取碼流類(lèi)型到type。 
// c語(yǔ)言實(shí)現(xiàn)上例 
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); 
  // 提取等號(hào)之前的內(nèi)容 
  memset(key, 0, sizeof(key)); 
  // sscanf使用的format不是正則表達(dá)式,不能用 \\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); 
  // 提取等號(hào)之后的內(nèi)容 
  memset(val, 0, sizeof(val)); 
  sscanf(line, "%*[^=]%*c%[^\n]", val); // 不包含了每行的換行符 
  Trim(val); 
  printf(" val: [%s]\n", val); 
  // 去除兩邊雙引號(hào) 
  // ... 
  // 插入map 
  // map[key]=value; 
  // string 轉(zhuǎn) 其它類(lèi)型 
  // atoi, atol, atof 
 } 
 printf("\n"); 
 fclose(fp); 
} 
// 上例的C++實(shí)現(xiàn) 
templateclass 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; 
   /// 提取等號(hào)之前的內(nèi)容 
   // 第1組()表示任意個(gè)空格字符,第2組()表示單詞(可帶_或-), 
   // 第3組()表示1個(gè)以上的空格字符(或=),最后以任意字符串結(jié)尾 
   regex reg("^([\\s]*)([\\w\\-\\_]+)([\\s=]+).*$"); 
   // 取第2組代替原串 
   string key = regex_replace(line, reg, "$2"); 
   cout  " key: {"  key  "}"  endl; 
   /// 提取等號(hào)之后的內(nèi)容 
   // 第1組()表示任意個(gè)空格字符,第2組()表示單詞(可帶_或-), 
   // 第3組()表示1個(gè)以上的空格字符(或=),第4組()表示任意個(gè)字符, 
   // 第5組()表示以任意個(gè)空格字符(或回車(chē)換行符)結(jié)尾。 
   reg = regex("^([\\s]*)([\\w\\-\\_]+)([\\s=]+)(.*)([\\s\\r\\n]*)$"); 
   // 取第4組代替原串 
   string val = regex_replace(line, reg, "$4"); 
   cout  " val: {"  val  "}"  endl; 
   // 去除兩邊雙引號(hào) 
   // ... 
   // 插入map 
   // map[key]=value; 
   // string 轉(zhuǎn) 其它類(lèi)型 
   // int i = parseToint>("123"); 
   // float f = parseTofloat>("1.23"); 
   // string str = parseTostring>(123); 
  } 
 } 
 else // 沒(méi)有該文件 
 { 
  cout  "no such file"  endl; 
 } 
} 
void main() 
{ 
 //test1(); 
 test2(); 
 test3(); 
} 
void lTrim(char * str) 
{ 
 int i, len; 
 len = strlen(str); 
 for (i = 0; ilen; 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 >= 0; 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; ilen; 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 >= 0; 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); 
} 
*/ 


以上所述是小編給大家介紹的使用正則表達(dá)式(regex_replace)模擬讀取INI文件,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

您可能感興趣的文章:
  • MySQL中使用replace、regexp進(jìn)行正則表達(dá)式替換的用法分析
  • 使用Linux正則表達(dá)式靈活搜索文件中的文本
  • jQuery獲取上傳文件的名稱(chēng)的正則表達(dá)式
  • FileUpload1 上傳文件類(lèi)型驗(yàn)證正則表達(dá)式

標(biāo)簽:廣元 大理 蚌埠 棗莊 江蘇 衢州 衡水 萍鄉(xiāng)

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《使用正則表達(dá)式(regex_replace)模擬讀取INI文件》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266