I have a string containg spaces and tags like:
<note label="description">sp|P02671|FIBA_HUMAN Fibrinogen alpha chain OS=Homo sapiens GN=FGA PE=1 SV=2</note>
我希望能够捕获“description”标签后和“OS=”前的内容。我在想是否可以使用sscanf和自定义符号来完成(请参见我当前的工作进展底部),或者使用第二个strstr函数解析OS会更好一些。谢谢。--更多信息--
if ( (p_str = (char*) strstr(buffer,"\"description\">")) ) {
sscanf(p_str+14,"%[^OS]",(file+teller)->description);
}
PS: %[^OS]会在第一个'O'出现的位置处截断字符串,我很想知道如何输入一组字符(如果可能的话)。
sscanf
是一个格式化函数,而memcpy
是许多编译器内置的函数,可能使用向量操作进行优化,在现代处理器上非常快速。如果您真的关心这些细节,请使用分析工具,尽管我相信在您的应用程序中有更大的瓶颈。;-) - md5