欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

C#计算两个文件的相对目录算法的实例代码

程序员文章站 2024-02-18 12:35:52
楼主大菜鸟一只,第一次写技术博客,如果有概念错误或代码不规范的地方,还请各位多多批评指正。话不多说,来看题: 前一阵子开发了一个用户控件,里面调用了很多css,js等资源...

楼主大菜鸟一只,第一次写技术博客,如果有概念错误或代码不规范的地方,还请各位多多批评指正。话不多说,来看题:

前一阵子开发了一个用户控件,里面调用了很多css,js等资源文件,而引用控件的页面所在目录是不同的。问题出来了:如果目录不同,那么控件里引用css,js资源文件的路径也会相应变化。现在已知两个文件相对于网站根目录的路径,如何计算相对路径呢?请看代码:

复制代码 代码如下:

public string getrelativepath(string path1, string path2)
{
            string[] path1array = path1.split('/');
            string[] path2array = path2.split('/');
            //
            int s = path1array.length >= path2array.length ? path2array.length : path1array.length;
            //两个目录最底层的共用目录索引
            int closestrootindex = -1;
            for (int i = 0; i < s; i++)
            {
                if (path1array[i] == path2array[i])
                {
                    closestrootindex = i;
                }
                else
                {
                    break;
                }
            }
            //由path1计算 ‘../'部分
            string path1depth = "";
            for (int i = 0; i < path1array.length; i++)
            {
                if (i > closestrootindex + 1)
                {
                    path1depth += "../";
                }
            }
            //由path2计算 ‘../'后面的目录
            string path2depth = "";
            for (int i = closestrootindex + 1; i < path2array.length; i++)
            {
                path2depth += "/" + path2array[i];
            }
            path2depth = path2depth.substring(1);

            return path1depth + path2depth;
}

我的算法,第一步算出两个目录的最底层父目录,第二步算出目录1需要向上级目录返回次数(../个数),第三步算出最底层父目录到目录2的相对路径,第四步把第二步和第三步的结果相加就是我们要的答案了。

调用部分:

复制代码 代码如下:

string path1 = "/manage/permissions/rolemanage.aspx";
string path2 = "/manage/plugin/jquery-easyui/jquery.easyui.min.js";
string result = getrelativepath(path1, path2);

得到结果:../plugin/jquery-easyui/jquery.easyui.min.js