boost::filesystem::recursive_directory_iterator
有一個path()
屬性,您可以查詢。然後,您可以使用下面的分解方法可用於boost::filesystem::path
手動生成的路徑進行比較:
path root_path() const;
path root_name() const; // returns 0 or 1 element path
path root_directory() const; // returns 0 or 1 element path
path relative_path() const;
path parent_path() const;
path filename() const; // returns 0 or 1 element path
path stem() const; // returns 0 or 1 element path
path extension() const; // returns 0 or 1 element path
例如,您可以首次展示版本剝離根如下:
#include <iostream>
#include <boost/filesystem.hpp>
boost::filesystem::path strip_root(const boost::filesystem::path& p) {
const boost::filesystem::path& parent_path = p.parent_path();
if (parent_path.empty() || parent_path.string() == "/")
return boost::filesystem::path();
else
return strip_root(parent_path)/p.filename();
}
int main() {
std::cout << strip_root("/a") << std::endl;
std::cout << strip_root("https://stackoverflow.com/a/b") << std::endl;
std::cout << strip_root("https://stackoverflow.com/a/b/c") << std::endl;
std::cout << strip_root("https://stackoverflow.com/a/b.dir/c.ext") << std::endl;
}
// Output:
""
"b"
"b/c"
"b.dir/c.ext"
的子方法可能是你最好的選擇。這是我比較兩個目錄樹時所做的。 –