2

我是 C# 的新手,被要求在我们的部署软件的插件中编写自定义任务,但我无法解决这个问题。我只是想将部署服务器上某个目录中的一些数据记录到输出日志中,但我只记录了第一个文件(然后甚至文本都是乱码,我认为它以某种方式加载了错误的字节)在收到有关“其他信息:集合已修改;枚举操作可能无法执行”的奇怪错误之前。

这是我到目前为止的代码:

class Clense : AgentBasedActionBase
{
    public string dataPath { get; set; }

    protected override void Execute()
    {
        IFileOperationsExecuter agent = Context.Agent.GetService<IFileOperationsExecuter>();
        GetDirectoryEntryCommand get = new GetDirectoryEntryCommand() { Path = dataPath };
        GetDirectoryEntryResult result = agent.GetDirectoryEntry(get);
        DirectoryEntryInfo info = result.Entry;
        // info has directory information
        List<FileEntryInfo> myFiles = info.Files.ToList();
        foreach (FileEntryInfo file in myFiles)
        {
            Byte[] bytes = agent.ReadFileBytes(file.Path);
            String s = Encoding.Unicode.GetString(bytes);
            LogInformation(s);
            // myFiles.Remove(file); 
        }
    }
}

有谁知道我能做些什么来解决这个问题?

更新

删除 myFiles.Remove() 修复了错误(我认为它会循环太多次,但事实并非如此),看起来我现在每个文件都有一个日志条目,但消息仍然是乱码。有谁知道为什么会这样?

4

3 回答 3

1

您可以以相反的方向myFiles迭代集合(这样当您删除每个单独的文件时不会损坏集合),或者您可以在完成迭代后简单地清除集合(这将完成同样的事情)。

于 2014-09-30T20:49:41.897 回答
1

您正在使用 myFiles.Remove(file); 修改集合;删除该行(因为它是原因)。

于 2014-09-30T20:49:54.000 回答
0

在他的评论中,关于用于读取磁盘上文件的编码,Blorgbeard 几乎可以肯定是正确的。请记住,这Encoding.Unicode实际上是 UTF16,这有点令人困惑,如果我不得不猜测,可能不是创建文件的编码。

ReadAllText()为了完整起见,我将使用以下扩展方法添加 BuildMaster 惯用方法来处理您的场景IFileOperationsExecuter

protected override void Execute()
{
    var agent = this.Context.Agent.GetService<IFileOperationsExecuter>();
    var entry = agent.GetDirectoryEntry(new GetDirectoryEntryCommand() { Path = dataPath }).Entry;
    foreach(var file in entry.Files) 
    {
        string contents = agent.ReadAllText(file.Path);
        this.LogInformation(contents);
    }
}

ReadAllText()方法将在内部采用 UTF8 编码,但如果需要,有一个重载可以接受不同的编码。

于 2014-10-07T20:52:10.103 回答