免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 3072 | 回复: 16
打印 上一主题 下一主题

[C] 字符串解析的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-10-31 05:59 |只看该作者 |倒序浏览
本帖最后由 gridbird 于 2012-10-31 06:00 编辑

要解析一个这样的多行内容


@ab ld:6362843 lib:hfskw_hds frm:fhskafhwekwf
@ab ld:6362664 lib:dddsr_hds frm:fhskadfwekwf

要得到每行的id和lib的内容,用perl的话很好解决。用strtok和strtok_r函数真的很难用,嵌套的话会处很多问题。 找了一下没有发现解析字符串的代码,各位谁有C字符串分割解析的建议和代码吗? 怕自己写的不好。



论坛徽章:
1
射手座
日期:2014-08-04 16:49:43
2 [报告]
发表于 2012-10-31 08:25 |只看该作者
不应该给你贴什么代码,其实也就是两三行的问题,关键是你基础太薄弱了...
我建议你还是自己去实现一下 m_strstr m_strtok两个函数, 然后在去看看旧版glibc 中 strstr strtok是如何实现的,毕竟基础才是王道,不要一蹴而就

论坛徽章:
14
巨蟹座
日期:2013-11-19 14:09:4615-16赛季CBA联赛之青岛
日期:2016-07-05 12:36:0515-16赛季CBA联赛之广东
日期:2016-06-29 11:45:542015亚冠之全北现代
日期:2015-07-22 08:09:472015年辞旧岁徽章
日期:2015-03-03 16:54:15巨蟹座
日期:2014-12-29 08:22:29射手座
日期:2014-12-05 08:20:39狮子座
日期:2014-11-05 12:33:52寅虎
日期:2014-08-13 09:01:31巳蛇
日期:2014-06-16 16:29:52技术图书徽章
日期:2014-04-15 08:44:01天蝎座
日期:2014-03-11 13:06:45
3 [报告]
发表于 2012-10-31 08:37 |只看该作者
fsanf 不行吗?

论坛徽章:
59
2015年亚洲杯之约旦
日期:2015-01-27 21:27:392015年亚洲杯之日本
日期:2015-02-06 22:09:41拜羊年徽章
日期:2015-03-03 16:15:432015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015元宵节徽章
日期:2015-03-06 15:50:392015年亚洲杯之阿联酋
日期:2015-03-19 17:39:302015年亚洲杯之中国
日期:2015-03-23 18:52:23巳蛇
日期:2014-12-14 22:44:03双子座
日期:2014-12-10 21:39:16处女座
日期:2014-12-02 08:03:17天蝎座
日期:2014-07-21 19:08:47
4 [报告]
发表于 2012-10-31 08:47 |只看该作者
回复 1# gridbird


    use regular expression if possible.
but if the context is context-sensitive, all that you can do is parse it characotr by charactor.

论坛徽章:
1
摩羯座
日期:2013-12-19 10:04:07
5 [报告]
发表于 2012-10-31 09:10 |只看该作者
sscanf 配合 %[]

论坛徽章:
0
6 [报告]
发表于 2012-10-31 09:15 |只看该作者
如果只是两三行代码的话,我还真想看看你怎么实现的。

回复 2# hanzhenlll


   

论坛徽章:
0
7 [报告]
发表于 2012-10-31 09:42 |只看该作者
。。。。。。。。。。。。这种都要用库函数
随手写个不仅效率高,还简单==

论坛徽章:
1
射手座
日期:2014-08-04 16:49:43
8 [报告]
发表于 2012-10-31 09:51 |只看该作者
回复 6# gridbird
  1. [code]void get_string (const char *in_buff, char *out_buff, const char *start_key, const char *end_key)
  2. {
  3.         int len = strlen (in_buff);
  4.         char *tmp_point;
  5.         printf ("buff ->[%s]\nkey1[%s], key2[%s]\n", in_buff, start_key, end_key);
  6.       
  7.         tmp_point = strstr (in_buff, start_key);
  8.         strcpy (out_buff, tmp_point);
  9.         strtok (out_buff, end_key);
  10. }
复制代码
[/code]
这里面核心的就三行 没有加出错处理,仅做展示使用...
  1. get_string (in_buff, out_buff, "ld:", " lib");  //outbuff 是最终获取到的关键字
复制代码

论坛徽章:
0
9 [报告]
发表于 2012-10-31 09:56 |只看该作者
LZ的数据格式已经接近JSON格式 建议用JSON格式 这样你就可以用开源的JSON lib对数据进行处理

论坛徽章:
0
10 [报告]
发表于 2012-10-31 11:08 |只看该作者
freebsd下面有个regex库,不知道linux下面有没有,可以直接使用正则表达式解析的话还真就两三行。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP