首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在Sprache解析器中使用Token()方法

如何在Sprache解析器中使用Token()方法
EN

Stack Overflow用户
提问于 2017-12-19 17:34:26
回答 1查看 228关注 0票数 0

我正在使用'Token()‘方法丢弃前导和尾随空格,但它不会,此测试失败,并显示消息Expected string to be "token", but it has unexpected whitespace at the end.

我试着在调用方法Text()之前调用方法Token(),但是也没有用。Parse.AnyChar.Many().Token().Text()

如何正确使用Token()方法?

代码语言:javascript
复制
[Test]
public void Test()
{
  Parser<string> parser = Parse.AnyChar.Many().Text().Token();
  var actual = parser.Parse(" token ");

  actual.Should().Be("token"); // without leading and trailing whitespaces
}
EN

回答 1

Stack Overflow用户

发布于 2018-01-05 09:46:29

Token修饰符生效之前,Parse.AnyChar会使用尾随空格。

要修复解析器,请像这样排除空格:

代码语言:javascript
复制
[Test]
public void Test()
{
    var parser = Parse.AnyChar.Except(Parse.WhiteSpace).Many().Text().Token();
    var actual = parser.Parse(" token ");

    actual.Should().Be("token"); // without leading and trailing whitespaces
}
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/47883869

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档