d - 解析文件和生成输出的正确方法



我正在尝试学习D,我想在做了hello world的事情之后,我可以尝试以前想在Java中做的事情,由于正则表达式API的工作方式,这是一个很大的痛苦:一个小模板引擎。因此,我从一些简单的代码开始,逐个字符地读取文件:

import std.stdio, std.file, std.uni, std.array;
void main(string [] args) {
    File f = File("src/res/test.dtl", "r"); 
    bool escape = false;
    char [] result;
    Appender!(char[]) appender = appender(result);
    foreach(c; f.rawRead(new char[f.size])) {
        if(c == '\') {
            escape = true;
            continue;
        }
        if(escape) {
            escape = false;
            // do something special
        }
        if(c == '@') {
            // start of scope
        }
        appender.put(c);
    }
    writeln(appender.data());
}

我的文件内容可能是这样的:

 <h1>@{hello}</h1>

目标是将 @{hello} 部分替换为传递给引擎的一些值。

所以,我实际上有两个问题:1. 这是处理 D 中文件中字符的好方法吗?在搜索了所有导入的模块并选择听起来可能完成这项工作的内容后,我将其破解在一起。2.有时,我想访问多个字符(以改进对转义序列的检查,找到整个范围等。 我应该为此对数组进行切片吗?还是 D 的正则表达式函数能够应对这一挑战?到目前为止,我只找到了 matchFirst 和 matchAll 方法,但我想匹配、替换并返回该位置。怎么能做到这一点呢?

D 标准库不提供您需要的内容。你需要的被称为"字符串插值",这里有一个非常好的D实现,你可以使用你描述的方式:https://github.com/Abscissa/scriptlike/blob/4350eb745531720764861c82e0c4e689861bb17e/src/scriptlike/core.d#L139

这是关于这个库的博客文章:https://p0nce.github.io/d-idioms/#String-interpolation-as-a-library

相关内容

  • 没有找到相关文章

最新更新