c語言字符串子串替換函數,C語言字符串替換指定字符串

本文目錄一覽:

C語言中子串替換函數

#includestdio.h

#includestring.h

#define N 80

void Displaces(char s1[],char s2[],char s3[])

{

char s4[N];

int i=0,j;

while(s1[i]!=’\0′)

{

if(s1[i]==s2[0])

{

for(j=0;jstrlen(s2);j++)

{

s4[j]=s1[j+i];

}

s4[j]=’\0′;

if(strcmp(s2,s4)==0)

{

for(j=0;jstrlen(s2);j++,i++)

{

s1[i]=s3[j];

}

}

else

i++;

}

else

i++;

}

}

int main(void)

{

char s1[N],s2[N],s3[N];

gets(s1);

gets(s2);

gets(s3);

Displaces(s1,s2,s3);

puts(s1);

return 0;

}

應該是這樣的吧。。。 給分吧!哪不明白可以找我!

C語言 實現子串替換函數:用子串r替換源串c中的子串p

#includestdio.h

#include stdlib.h

#include string.h

void replace_string(char *c, const char *p, const char *r);

int main()

{

char c[100] = “you are the best,you should word hard,and you will be success!”;

char p[] = “you”;

char r[] = “LGDDD”;

replace_string(c, p, r);

printf(“替換後:”);

puts(c);

return 0;

}

void replace_string(char *c, const char *p, const char *r)

{

int i = 0, j = 0;

while (c[j] = c[i])

{

int len = strlen(c);

int len1 = strlen(p);

int len2 = strlen(r);

int m = i;

int n = 0;

for (; c[m] == p[n]  p[n]; m++, n++);

if (p[n] != 0)

{

i++;

j++;

}

else

// i = i + strlen(p);

 if (len2  len1)

{

int m1,n1;

for (m1 = len; m1 = i + strlen(p); m1–)

c[m1 + len2-len1] = c[m1];

// puts(c);

for (n1 = i, m1 = 0; m1  len2; m1++, n1++)

c[n1] = r[m1];

}

else if (len2 = len1)

{

int m1, n1;

for (m1 = i + len1 – len2, n1 = 0; n1  len2; n1++, m1++)

c[m1] = r[n1];

i = i + len1 – len2;

}

}

}

c語言 子串替換

char  *replace(char  *source,  char  *sub,  char  *rep) 

{ 

 char  *result; 

 /*pc1  是複製到結果result的掃描指針*/

 /*pc2  是掃描 source 的輔助指針*/

 /*pc3  尋找子串時,為檢查變化中的source是否與子串相等,是指向sub的掃描指針 */

 /*找到匹配後,為了複製到結果串,是指向rep的掃描指針*/

 char  *pc1,  *pc2,  *pc3; 

 int  isource,  isub,  irep; 

 isub  = strlen(sub); /*對比字符串的長度*/

 irep  = strlen(rep); /*替換字符串的長度*/

 isource= strlen(source); /*源字符串的長度*/ 

 if(NULL == *sub)

  return strdup(source); 

 /*申請結果串需要的空間*/

 result  = (char *)malloc(( (irep isub) ? (float)strlen(source) / isub* irep+ 1:isource ) * sizeof(char));

 pc1  =  result; /*為pc1依次複製結果串的每個字節作準備*/

 while(*source  !=  NULL) 

 { 

  /*為檢查source與sub是否相等作準備,為pc2,pc3 賦初值*/

 pc2  =  source; 

 pc3  =  sub;

  /* 出循環的(任一)條件是: 

*  *pc2 不等於 *pc3 (與子串不相等) 

*  pc2  到源串結尾 

*  pc3  到源串結尾 (此時,檢查了全部子串,source處與sub相等) 

*****************************************************/

 while(*pc2  ==  *pc3    *pc3  !=  NULL    *pc2  !=  NULL) 

 pc2++,  pc3++; [Page]

  /* 如果找到了子串,進行以下處理工作*/

 if(NULL  ==  *pc3) 

 { 

 pc3  =  rep; 

/*將替代串追加到結果串*/

 while(*pc3  !=  NULL) 

 *pc1++  =  *pc3++; 

 pc2–; 

 source  =  pc2; 

/* 檢查 source與sub相等的循環結束後, 

* pc2 對應的位置是在 sub 中串結束符處。該是源串中下一個位置。 

* 將 source 指向其前面一個字符。 

***************************************************/

 } 

 else /*如果沒找到子串,下面複製source所指的字節到結果串*/ 

 *pc1++ = *source; 

 source++; /* 將source向後移一個字符*/ 

 } 

 *pc1  =  NULL;

 return  result;

}

以下為測試代碼:

int main()

{

  char s1[] =”abbccdfdcdbbdcd”;

 char s2[]=”dcd”;

char s3[]=”12345″;

char *p = replace(s1,s2,s3);

printf(“source=%s

“,s1);

puts(s1);

  printf(“sub = %s

“,s2);

puts(s2);

  printf(“replace string = %s”,p);

return 0;

}

c語言 字符串替換函數

替換函數主要有strtr(),str_repalce()這兩個函數。

首先針對strtr函數第一種方式:

我們看看下面的舉例:

?php

echo strtr(“I Love you”,”Lo”,”lO”);

?

得到的結果是:

I lOve yOu

這個結果提醒我們:

1.strtr它是區分大小寫的

2.strtr的替換是很特殊的,你注意看後面那個yOu,中間的O被替換的,這顯然不是我們的本意。

再舉一個特殊例子,說明這個php的sttr函數的怪異

?php

echo strtr(“I Love you”,”Love”,””);

?

結果是:

I Love you

什麼也不會改變,所以strtr需要注意的是:

3.不能被替換為空,也就是末位那個參數不能是空字符串,當然空格是可以的。

再次舉例strtr函數的另一種情況:

?php

echo strtr(“I Loves you”,”Love”,”lOvEA”);

?

結果是:

I lOvEs yOu

注意看第三個參數的A,在結果中並沒有出現。

4.我不建議用strtr以少換多。

ok,既然這個strtr函數挺麻煩為什麼還要用呢?

原因是,它的速度很快。據說,strtr 比 str_replace 快四倍。

5.能用strtr函數的時候一定要用。

第二種情況:

strtr(string,array)

6.strtr符合意願的使用方法

?php

$table_change = array(‘you’=’her sister’);

echo strtr(“I Love you”,$table_change);

?

結果為:

I Love her sister

7.小技巧:你想到替換什麼你就往數組加什麼

比如:

?php

$table_change = array(‘you’=’her sister’);

$table_change += array(‘Love’ = ‘hate’);

echo strtr(“I Love you”,$table_change);

?

結果是:

I hate her sister

再次提醒那個Love 寫成love 是行不通的哦。

字符串取代。

語法: string str_replace(string needle, string str, string haystack);

返回值: 字符串

函數種類: 資料處理

內容說明

本函數將字符串 str 代入 haystack 字符串中,將所有的 needle 置換成 str。

下例將 %body% 以 black 取代

?php

$bodytag = str_replace(“%body%”, “black”, “body text=%body%”);

echo $bodytag;

?

格式:

[@str_replace(“要替換的舊內容”, “要取代原內容的新字符”, $被替換內容的變量名)]

[@str_replace(array(‘舊1′,’舊2′,’舊3’), array(‘新1′,’新2′,’新3’), $被替換內容的變量名)]

[@str_replace(array(‘舊1′,’舊2′,’舊3’), ‘新內容’, $被替換內容的變量名)]

實例:

多對一替換:想把內容字段里所有的p/p標籤清除掉,替換成空 [@str_replace(array(‘p’,’/p’), ”, $Content)]

一對一替換:想把內容字段里所有的br標籤換成p [@str_replace(‘br’, ‘p’, $Content)]

多對多替換:想把內容字段里的br換成br /, 同時p換hr,把/p全清除 [@str_replace(array(‘br’, ‘p’,’/p’), array(‘br /’,’hr’,”), $Content)]

原創文章,作者:TLPZ,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/147226.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
TLPZ的頭像TLPZ
上一篇 2024-11-01 14:07
下一篇 2024-11-01 14:07

相關推薦

  • Python中引入上一級目錄中函數

    Python中經常需要調用其他文件夾中的模塊或函數,其中一個常見的操作是引入上一級目錄中的函數。在此,我們將從多個角度詳細解釋如何在Python中引入上一級目錄的函數。 一、加入環…

    編程 2025-04-29
  • Python中capitalize函數的使用

    在Python的字符串操作中,capitalize函數常常被用到,這個函數可以使字符串中的第一個單詞首字母大寫,其餘字母小寫。在本文中,我們將從以下幾個方面對capitalize函…

    編程 2025-04-29
  • Python字符串寬度不限制怎麼打代碼

    本文將為大家詳細介紹Python字符串寬度不限制時如何打代碼的幾個方面。 一、保持代碼風格的統一 在Python字符串寬度不限制的情況下,我們可以寫出很長很長的一行代碼。但是,為了…

    編程 2025-04-29
  • Python中set函數的作用

    Python中set函數是一個有用的數據類型,可以被用於許多編程場景中。在這篇文章中,我們將學習Python中set函數的多個方面,從而深入了解這個函數在Python中的用途。 一…

    編程 2025-04-29
  • Python中將字符串轉化為浮點數

    本文將介紹在Python中將字符串轉化為浮點數的常用方法。在介紹方法之前,我們先來思考一下這個問題應該如何解決。 一、eval函數 在Python中,最簡單、最常用的將字符串轉化為…

    編程 2025-04-29
  • 三角函數用英語怎麼說

    三角函數,即三角比函數,是指在一個銳角三角形中某一角的對邊、鄰邊之比。在數學中,三角函數包括正弦、餘弦、正切等,它們在數學、物理、工程和計算機等領域都得到了廣泛的應用。 一、正弦函…

    編程 2025-04-29
  • 單片機打印函數

    單片機打印是指通過串口或並口將一些數據打印到終端設備上。在單片機應用中,打印非常重要。正確的打印數據可以讓我們知道單片機運行的狀態,方便我們進行調試;錯誤的打印數據可以幫助我們快速…

    編程 2025-04-29
  • Python3定義函數參數類型

    Python是一門動態類型語言,不需要在定義變量時顯示的指定變量類型,但是Python3中提供了函數參數類型的聲明功能,在函數定義時明確定義參數類型。在函數的形參後面加上冒號(:)…

    編程 2025-04-29
  • Java判斷字符串是否存在多個

    本文將從以下幾個方面詳細闡述如何使用Java判斷一個字符串中是否存在多個指定字符: 一、字符串遍歷 字符串是Java編程中非常重要的一種數據類型。要判斷字符串中是否存在多個指定字符…

    編程 2025-04-29
  • AES加密解密算法的C語言實現

    AES(Advanced Encryption Standard)是一種對稱加密算法,可用於對數據進行加密和解密。在本篇文章中,我們將介紹C語言中如何實現AES算法,並對實現過程進…

    編程 2025-04-29

發表回復

登錄後才能評論