4

我正在使用 Dropbox 的 Delta API,当我调用 delta 方法时,我得到了自上次调用以来更改的路径列表。

/photos 
/public 
/photos/sample album 
/photos/sample album/boston city flow.jpg 
/photos/sample album/pensive parakeet.jpg 
/photos/sample album/costa rican frog.jpg 
/getting started.pdf 
/photos/how to use the photos folder.txt 
/public/how to use the public folder.txt 
/ies eai.pptx 
/documents 
/documents/windows phone toolkit in depth 2nd edition.pdf 
/prashant 
/prashant/iphone indexed list.bmml 
/photos/flower.jpg 
/photos/trs 
/photo.jpg 
/hello1 
/hello1/new 

我很难通过操纵字符串来创建分层(在下面提到的类中)结构,任何人都可以提出我可以实现它的方法/想法。

public class DeltaItem
{

    private List<DeltaItem> _items;
    public string Path { get; set; }
    public bool IsDir { get; set; }

    public List<DeltaItem> Items
    {
        get
        {
            return _items ?? (_items = new List<DeltaItem>());
        }
    }
}
4

2 回答 2

10

这是一个非常简单的解析操作。首先,我会这样定义类:

public class Node
{
    private readonly IDictionary<string, Node> _nodes = 
        new Dictionary<string, Node>();

    public string Path { get; set; }
}

从那里开始,这是一个问题:

  1. 解析路径(\用作分隔符)。
  2. 遍历树,必要时添加新节点。

您可以将上述内容包装在一个方法中Add

public void AddPath(string path)
{
   char[] charSeparators = new char[] {'\\'};

   // Parse into a sequence of parts.
   string[] parts = path.Split(charSeparators, 
       StringSplitOptions.RemoveEmptyEntries);

   // The current node.  Start with this.
   Node current = this;

   // Iterate through the parts.
   foreach (string part in parts)
   {
       // The child node.
       Node child;

       // Does the part exist in the current node?  If
       // not, then add.
       if (!current._nodes.TryGetValue(part, out child))
       {
           // Add the child.
           child = new Node {
               Path = part
           };

           // Add to the dictionary.
           current._nodes[part] = child;
       }

       // Set the current to the child.
       current = child;
   }
}

这将为您提供所需的层次结构。您可以公开对字典起作用的操作,这将允许您遍历它,但这是您填充您将使用的一般结构的方式。

请注意,您将从一个没有的奇异节点开始Path,然后遍历上面的列表并调用上面AddPath列表中的每个项目。

于 2012-06-05T02:51:36.260 回答
-1

@casperOne 解决方案很好,但只有在您使用时才能与问题中的列表一起使用

char[] charSeparators = new char[] {'/'};

而不是

char[] charSeparators = new char[] {'\\'};
于 2014-07-11T08:01:54.520 回答