用参数值替换硬编码的问题

problem replacing hardcoded with parameter values

我的 BIML 文件中有这个结构:

myColumns = myFile.ReadLine().Replace("\"","").Split('|');

我想将其替换为:

myColumns = myFile.ReadLine().Replace("\"","").Split('<#=delimiter#>');

但显然这不起作用。不知怎的语法高亮告诉我这不起作用.....

另外:

string[] myFiles = Directory.GetFiles(path, "*.csv");

string[] myFiles = Directory.GetFiles(path, "*.<#=filetype#>");

简单使用时

 myColumns = myFile.ReadLine().Replace("\"","").Split('delimiter');

它告诉我Cannot implicitly convert type 'string' to 'char'

定界符声明为string delimiter ="|"

将其更改为 char delimiter ="|" 时,我得到了完全相同的错误,但是在我声明定界符的那一行......

如果我对你的理解正确,你文件的这一部分:

myColumns = myFile.ReadLine().Replace("\"","").Split('|');

将已经包含在代码块或单独的代码文件中,是吗?如果是这样,您不需要使用另一个代码块对 delmiter 进行参数化,而只需引用该变量,假设您已经在某处声明了它:

<#
...
char delimiter = '|';
...
var myColumns = myFile.ReadLine().Replace("\"","").Split(delimiter);
...
#>

针对您的评论,使用此代码在您的 Biml 文件中可能看起来像这样?

...
 <Tables>
  <Table Name="TableName" etc>
    <Columns>
    <# // This is the start of a Code Block

     // We can define some C# data structures
     char delimiter = '|';
     var myColumns = myFile.ReadLine().Replace("\"","").Split(delimiter);

     // Then start a loop which will generate some Biml nodes
     foreach(string col in myColumns)
     {
      // Note that the foreach loop is left open despite closing the code block on the next line.
      // This means the following Biml is looped over until the foreach ends.
    #>
     <Column Name="<#=col#>" etc />
    <# // We can then start another code block which carries on from the last one
     } // This closes the foreach loop defined earlier
    #>
    </Columns>
  </Table>
 </Tables>
...

在此示例中,您可以看到 C# 代码如何包含在 <##> 标记中,而在其他任何地方都包含原始 Biml。 <#=#> 标记的使用是引用先前定义的 C# 变量的语法快捷方式。这些显然只有在文件的 Biml 部分内而不是代码块内时才需要。