LINQPad转储(toDataGrid)不会显示直到执行结束

时间:2015-01-08 21:22:37

标签: c# linqpad

我正在使用LINQPad中的一个小脚本进行自动批量邮寄。尽管脚本验证了数据,但我希望由某人和他的确认进行检查。而且,以下是我在理智检查中的尝试:

var datasource = Enumerable.Range(0, 10) //not actual data
    .Dump("Data", true);

var message = string.Format("Please enter {0} to confirm or -1 to cancel : ", datasource.Count());
var container = new DumpContainer(message).Dump("Last Confirmation");
do
{
    var result = Console.ReadLine();
    container.Content = (container.Content as string) + result;

    if (result == "-1") return;
    if (result == datasource.Count().ToString()) break;

    container.Content = (container.Content as string) + "\n" + message;
} while (true);

//do stuffs...

大多数工作都很好,除了datasource在执行结束之前没有被转储,这会破坏这段代码的整个目的。如何立即显示“数据”选项卡?

请注意,我打算将datasource转储到新的DataGrid标签中,因为它无法轻松扫描或导出到Excel。

2 个答案:

答案 0 :(得分:2)

现在已在v4.51.03中修复(在撰写本文时为测试版)。

使用新的Util.ReadLineAsync方法:

for (int i = 0; i < 10; i++)
{
    int x = await Util.ReadLineAsync<int> ("Enter a number");
    Enumerable.Range (0, x).Dump (x + " integers", true);
}

答案 1 :(得分:0)

我发现这是一个解决此问题的作弊:Hyperlinq

void Main()
{
    var datasource = Enumerable.Range(0, 10) //not actual data
        .Dump("Data", true);

    Console.Write("Please confirm everything is correct : "); //couldnt manage to get them to dump on same line
    new Hyperlinq(() => DoStuffs(datasource), "Do Stuffs").Dump();
}

// Define other methods and classes here
public void DoStuffs(IEnumerable<int> datasource)
{
    datasource.Select(x => 2 * x).Dump("Altered Data", true);


    new Hyperlinq(() => DoStuffs(datasource), "Do More Stuffs").Dump();
}

这个作弊也引入了一个小烦恼/错误。当数据网格中没有足够的行占用整个区域时,会抛出ArgumentOutOfRangeException并转储到结果面板,但不会破坏执行流程。