c语言编程,关于sscanf通过中文逗号截取字符串的问题

我用英文逗号匹配字符串charbuf[100]={"+++Text1,Text2,Text3,Text4,Text5,Text6"};sscanf(buf+3,"%[^,... 我用英文逗号匹配字符串

char buf[100] = {"+++Text1,Text2,Text3,Text4,Text5,Text6"};
sscanf(buf+3, "%[^,],%[^,],%[^,],%[^,],%[^,],%s", buf1,buf2,buf3,buf4,buf5,buf6);
这样是可以获取到数据的,如果我把字符串改成
char buf[100] = {"+++Text1,Text2,Text3,Text4,Text5,Text6"};
sscanf(buf+3, "%[^,],%[^,],%[^,],%[^,],%[^,],%s", buf1,buf2,buf3,buf4,buf5,buf6);
这样就匹配不到了,我想请教下大神对于sscanf匹配中文符号和英文符号有什么不同,要怎么匹配呢?
展开
 我来答
百度网友30a3645
2013-07-26 · TA获得超过531个赞
知道小有建树答主
回答量:446
采纳率:0%
帮助的人:179万
展开全部
C语言sscanf函数的总结
在处理字符串的程序当中,经常会分析字符串,从一大长串的字符串截取我们需要的数据,这如果通过自己手写函数来分析,虽然可以,但当你知道sscanf的功能,那就自己写函数分析就显得多此一举。

这些函数的使用都很简单,总结一下,等下次使用一目了然。俗话说:好记性不如烂笔头,记录下来就是效率。

以下源代码是本人测试的源文件,附带讲解注释。

1./*****************************************************
2.** Name : sscanf.c
3.** Author : gzshun
4.** Version : 1.0
5.** Date : 2011-12
6.** Description : sscanf function
7.******************************************************/
8.#include <stdio.h>
9.#include <stdlib.h>
10.#include <string.h>
11.
12.static void sscanf_test(void);
13.
14.static void sscanf_test(void)
15.{
16. int ret;
17. char *string;
18. int digit;
19. char buf1[255];
20. char buf2[255];
21. char buf3[255];
22. char buf4[255];
23.
24. /*1.最简单的用法*/
25. string = "china beijing 123";
26. ret = sscanf(string, "%s %s %d", buf1, buf2, &digit);
27. printf("1.string=%s\n", string);
28. printf("1.ret=%d, buf1=%s, buf2=%s, digit=%d\n\n", ret, buf1, buf2, digit);
29. /*
30. **执行结果:
31. **1.ret=2, buf1=china, buf2=beijing, digit=123
32. **可以看出,sscanf的返回值是读取的参数个数
33. */
34.
35. /*2.取指定长度的字符串*/
36. string = "123456789";
37. sscanf(string, "%5s", buf1);
38. printf("2.string=%s\n", string);
39. printf("2.buf1=%s\n\n", buf1);
40. /*
41. **执行结果:
42. **2.buf1=12345
43. */
44.
45. /*3.取到指定字符为止的字符串*/
46. string = "123/456";
47. sscanf(string, "%[^/]", buf1);
48. printf("3.string=%s\n", string);
49. printf("3.buf1=%s\n\n", buf1);
50. /*
51. **执行结果:
52. **3.buf1=123
53. */
54.
55. /*4.取到指定字符集为止的字符串*/
56. string = "123abcABC";
57. sscanf(string, "%[^A-Z]", buf1);
58. printf("4.string=%s\n", string);
59. printf("4.buf1=%s\n\n", buf1);
60. /*
61. **执行结果:
62. **4.buf1=123abc
63. */
64.
65. /*5.取仅包含指定字符集的字符串*/
66. string = "0123abcABC";
67. sscanf(string, "%[0-9]%[a-z]%[A-Z]", buf1, buf2, buf3);
68. printf("5.string=%s\n", string);
69. printf("5.buf1=%s, buf2=%s, buf3=%s\n\n", buf1, buf2, buf3);
70. /*
71. **执行结果:
72. **5.buf1=123
73. */
74.
75. /*6.获取指定字符中间的字符串*/
76. string = "ios<Android>wp7";
77. sscanf(string, "%*[^<]<%[^>]", buf1);
78. printf("6.string=%s\n", string);
79. printf("6.buf1=%s\n\n", buf1);
80. /*
81. **执行结果:
82. **6.buf1=android
83. */
84.
85. /*7.指定要跳过的字符串*/
86. string = "iosVSandroid";
87. sscanf(string, "%[a-z]VS%[a-z]", buf1, buf2);
88. printf("7.string=%s\n", string);
89. printf("7.buf1=%s, buf2=%s\n\n", buf1, buf2);
90. /*
91. **执行结果:
92. **7.buf1=ios, buf2=android
93. */
94.
95. /*8.分割以某字符隔开的字符串*/
96. string = "android-iphone-wp7";
97. /*
98. **字符串取道'-'为止,后面还需要跟着分隔符'-',
99. **起到过滤作用,有点类似于第7点
100. */
101. sscanf(string, "%[^-]-%[^-]-%[^-]", buf1, buf2, buf3);
102. printf("8.string=%s\n", string);
103. printf("8.buf1=%s, buf2=%s, buf3=%s\n\n", buf1, buf2, buf3);
104. /*
105. **执行结果:
106. **8.buf1=android, buf2=iphone, buf3=wp7
107. */
108.
109. /*9.提取邮箱地址*/
110. string = "Email:beijing@sina.com.cn";
111. sscanf(string, "%[^:]:%[^@]@%[^.].%s", buf1, buf2, buf3, buf4);
112. printf("9.string=%s\n", string);
113. printf("9.buf1=%s, buf2=%s, buf3=%s, buf4=%s\n\n", buf1, buf2, buf3, buf4);
114. /*
115. **执行结果:
116. **9.buf1=Email, buf2=beijing, buf3=sina, buf4=com.cn
117. */
118.}
119.
120.int main(int argc, char **argv)
121.{
122. sscanf_test();
123.
124. return 0;
125.}
126.
127./*
128.**测试程序
129.**环境:
130.**Linux Ubuntu 2.6.32-24-generic-pae #39-Ubuntu SMP Wed Jul 28 07:39:26 UTC 2010 i686 GNU/Linux
131.**gcc version 4.4.3 (Ubuntu 4.4.3-4ubuntu5)
132.**
133.gzshun@ubuntu:~/c/sscanf$ gcc sscanf.c -o sscanf
134.gzshun@ubuntu:~/c/sscanf$ ./sscanf
135.1.string=china beijing 123
136.1.ret=3, buf1=china, buf2=beijing, digit=123
137.
138.2.string=123456789
139.2.buf1=12345
140.
141.3.string=123/456
142.3.buf1=123
143.
144.4.string=123abcABC
145.4.buf1=123abc
146.
147.5.string=0123abcABC
148.5.buf1=0123, buf2=abc, buf3=ABC
149.
150.6.string=ios<android>wp7
151.6.buf1=android
152.
153.7.string=iosVSandroid
154.7.buf1=ios, buf2=android
155.
156.8.string=android-iphone-wp7
157.8.buf1=android, buf2=iphone, buf3=wp7
158.
159.9.string=Email:beijing@sina.com.cn
160.9.buf1=Email, buf2=beijing, buf3=sina, buf4=com.cn
161.*/

本篇文章来源于 Linux公社网站(www.linuxidc.com) 原文链接:http://www.linuxidc.com/Linux/2011-12/49711.htm
liyakang126
2013-07-26 · TA获得超过122个赞
知道答主
回答量:53
采纳率:0%
帮助的人:59.9万
展开全部
你可以使用%[a-zA-Z0-9]这样的形式来取你想要取的字符,还有sscanf格式字符之间不要用符号来隔开吧!如果使用符号来隔开格式说明的话就要输入格式说明间的字符来作为两带输入的变量的分隔。
如scanf(%d,%d,i1,i2);这样输入时必须要是1,2这样输入,要是%s输入字符串的话我不太清楚。
还有,中文字符编码是两个字节的,%[^,]是不对的,就像楼上说的^后面必须接单字节字符,如果你将中文字符拆分为两个字节,将两个字节分别以转义形式屏蔽的话也许可以。我电脑没装vs,所以没测试,你可以去测试一下看看。^_^
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
沧海雄风2009
推荐于2016-07-06 · TA获得超过1.1万个赞
知道大有可为答主
回答量:8525
采纳率:79%
帮助的人:2868万
展开全部
首先我要大言不惭说一句 在C/C++版块 折腾文件 字符串 我也是前十名的人物

然后我反驳一下 楼上 sscanf是可以用正则表达式的

接下来 我回答楼主

%[^,] 这样的结构 ^后面的是单字符

而不是中文的 逗号 是双字节的

在C里算是 字符串

因此不能用在这里
追问
自己研究很久了,还是不会替换,因为比较急着改代码,所以还是要向你请教下。就是要把中文逗号全部替换为英文逗号,中文逗号不是两个字节么,要怎么替换呢。非常感谢啊
追答
#include <stdio.h>
#include <string.h>
#include <malloc.h>

char * replace(char *str, char *str1, char *str2)
{
char *str_temp = str;
char *str1_temp = str1;
char *str2_temp = str2;
char *strretu_temp = NULL;

unsigned long char_size = (unsigned long)sizeof(char);
/*计算字符长度*/
unsigned long i,j,rep_acc = 0;
unsigned long str_len = strlen(str);
unsigned long str1_len = strlen(str1);
unsigned long str2_len = strlen(str2);

/*首先找出Str里有几个地方要被替换的*/
for(; str_temp - str < str_len; )
{
for(i = 0; i < str1_len; i++)
{
if(*str_temp++ != *str1_temp++)
{
str1_temp = str1;
break;
}
else
{
if(i == str1_len - 1)
{
str1_temp = str1;
rep_acc++;
}
}
}
}
str1_temp = str1;
str_temp = str;

/*分配所需内存*/
strretu = strretu_temp = (char*) malloc(((str_len - str1_len * rep_acc) + str2_len * rep_acc + 1) * char_size);
/*替换*/
for(; str_temp - str < str_len; )
{

for(i = 0; i < str1_len; i++)
{
*strretu_temp++ = *str_temp;

if(*str_temp++ != *str1_temp++)
{
str1_temp = str1;
break;
省略  太长贴不下  我上传txt

 

本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
cooke1234
2013-07-26 · TA获得超过6861个赞
知道大有可为答主
回答量:4617
采纳率:72%
帮助的人:3617万
展开全部
sscanf不支持中文,也不支持正则表达式。
sscanf对中文进行扫描,结果不可预知。

你可以在字符串中,自己查找逗号,然后再从逗号开始出sscanf。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式