Mac的finder如何查看最基层目录,就像windows的目录:我的电脑本地磁盘C 一样

Mac的finder如何查看最基层目录,就像windows的目录:我的电脑本地磁盘C 一样,第1张

其实使用递归算法很容易,不管你的文件夹有几层都能轻松搞定

//声明变量

ArrayList arrlist = new ArrayList(); //存放zip文件的FileInfo[]

//递归方法

void GetZipFiles(string dirBase)

{

DirectoryInfo di = new DirectoryInfo(dirBase); //根据基目录创建DirectoryInfo类

FileInfo[] zipFiles = diGetFiles("zip"); //获取基目录下所有的zip文件信息

if(zipFilesLength > 0) //如果有zip文件,则放入集合中

{

arrlistAdd(zipFiles);

}

DirectoryInfo[] diSub = diGetDirectories(); //获取基目录下所有的子目录信息

foreach(Directory d in diSub) //循环子目录递归调用

{

GetZipFiles(dFullName);

}

}

//方法调用

GetZipFiles(@"c:\123");

C#获取当前路径的方法如下:

1、SystemDiagnosticsProcessGetCurrentProcess()MainModuleFileName

-获取模块的完整路径。

2、SystemEnvironmentCurrentDirectory

-获取和设置当前目录(该进程从中启动的目录)的完全限定目录。

3、SystemIODirectoryGetCurrentDirectory()

-获取应用程序的当前工作目录。这个不一定是程序从中启动的目录啊,有可能程序放在C:\>

stringstr1=ProcessGetCurrentProcess()MainModuleFileName;//可获得当前执行的exe的文件名。\x0d\stringstr2=EnvironmentCurrentDirectory;//获取和设置当前目录(即该进程从中启动的目\x0d\录)的完全限定路径。\x0d\//备注按照定义,如果该进程在本地或网络驱动器的根目录中启动,则此属性的值为驱\x0d\动器名称后跟一个尾部反斜杠(如"C:\")。如果该进程在子目录中启动,则此属性的值为不\x0d\带尾部反斜杠的驱动器和子目录路径(如"C:\mySubDirectory")。\x0d\stringstr3=DirectoryGetCurrentDirectory();//获取应用程序的当前工作目录。\x0d\stringstr4=AppDomainCurrentDomainBaseDirectory;//获取基目录,它由程序集冲突解决\x0d\程序用来探测程序集。\x0d\stringstr5=ApplicationStartupPath;//获取启动了应用程序的可执行文件的路径,不包括可\x0d\执行文件的名称。\x0d\stringstr6=ApplicationExecutablePath;//获取启动了应用程序的可执行文件的路径,包括可\x0d\执行文件的名称。\x0d\stringstr7=AppDomainCurrentDomainSetupInformationApplicationBase;//获取或设置包含\x0d\该应用程序的目录的名称。\x0d\1SystemDiagnosticsProcessGetCurrentProcess()MainModuleFileName获取模块的完整路径。\x0d\2SystemEnvironmentCurrentDirectory获取和设置当前目录(该进程从中启动的目录)的\x0d\完全限定目录。\x0d\3SystemIODirectoryGetCurrentDirectory()获取应用程序的当前工作目录。这个不一定\x0d\是程序从中启动的目录啊,有可能程序放在C:\>

获取当前程序文件的路径也算是一个比较常见的需求 比如我有一个文件conn xml位于 exe的同一目录 在运行时需要从中读取一些设置信息

string str =Process GetCurrentProcess() MainModule FileName;//可获得当前执行的exe的文件名

string str =Environment CurrentDirectory;//获取和设置当前目录(即该进程从中启动的目录)的完全限定路径

//备注 按照定义 如果该进程在本地或网络驱动器的根目录中启动 则此属性的值为驱动器名称后跟一个尾部反斜杠(如 C:\ ) 如果该进程在子目录中启  动 则此属性的值为不带尾部反斜杠的驱动器和子目录路径(如 C:\mySubDirectory )

string str =Directory GetCurrentDirectory();//获取应用程序的当前工作目录

string str =AppDomain CurrentDomain BaseDirectory;//获取基目录 它由程序集冲突解决程序用来探测程序集

string str =Application StartupPath;//获取启动了应用程序的可执行文件的路径 不包括可执行文件的名称

string str =Application ExecutablePath;//获取启动了应用程序的可执行文件的路径 包括可执行文件的名称

string str =AppDomain CurrentDomain SetupInformation ApplicationBase;//获取或设置包含该应用程序的目录的名称

System Diagnostics Process GetCurrentProcess() MainModule FileName

获取模块的完整路径

System Environment CurrentDirectory

获取和设置当前目录(该进程从中启动的目录)的完全限定目录

System IO Directory GetCurrentDirectory()

获取应用程序的当前工作目录 这个不一定是程序从中启动的目录啊 有可能程序放在C:\里 这个函数有可能返回C:\Documents and Settings\ZYB\ 或者C:\Program Files\Adobe\ 有时不一定返回什么东东 我也搞不懂了

System AppDomain CurrentDomain BaseDirectory

获取程序的基目录

System AppDomain CurrentDomain SetupInformation ApplicationBase

获取和设置包括该应用程序的目录的名称

System Windows Forms Application StartupPath

获取启动了应用程序的可执行文件的路径 效果和 一样 只是 返回的字符串后面多了一个 \ 而已

System Windows Forms Application ExecutablePath

获取启动了应用程序的可执行文件的路径及文件名 效果和 一样

对于Windows程序 和Web 应用程序来说 他们运行的路径是不一样的 所以关键是判断当前运行的程序是哪种程序 于是我们可以使用如下的代码  string path = ;

if (System Environment CurrentDirectory == appDomain CurrentDomain BaseDirectory)//Windows应用程序则相等

{

path = AppDomain CurrentDomain BaseDirectory;

}

else

{

path = AppDomain CurrentDomain BaseDirectory + Bin\ ;

}

这样如果我们写了一个类库 类库中用到了Assembly LoadFrom 由于是通用类库 所以可能用到Windows程序中也可能用到Web中 那么用上面的代码就很方便了

Server MapPath

System Windows Forms StartupPath

Type Assembly Location

方法 可以应用于控制台应用程序 WinForm应用程序 Windows服务 方法 可以应用于Web应用程序 方法 都可以应用

但方法 是加载应用程序的路径 如果是Web应用程序 取得的路径是C:\WINDOWS\Microsoft NET\Framework\v \Temporary ASP NET Files目录 所以Web项目还是使用Server MapPath吧 否则建议使用方法 如果自己新建类库 可以加入对System Windows Forms StartupPath的引用后使用

进程对象在 NET中表现为System Diagnostics Process类 通过调用Process GetCurrentProcess() MainModule FileName可获得当前执行的exe的文件名 但是这个方法得到的仅仅是文件名 如果程序运行期间没有切换工作目录 那么可以调用System IO Path的方法获取绝对路径 但是当前目录同样可以通过Environment CurrentDirectory获得 而且很多软件在使用Open Dialog打开文件的时候 都会切换工作目录 而使得这一机制失效

如果是在Windows Forms应用程序中 当前应用也表现为System Windows Forms Application对象 通过其静态属性Application ExecutablePath和Application StartupPath 可以取得可执行文件的路径和启动路径

但如果不是在Windows应用中呢 或者是在Library中呢 就算是Application对象的属性依然能获得 也需要在工程中添加System Windows Forms这个Assembly的引用 非常不方便 这个时候 可以通过Assembly的静态方法 GetCallingAssembly或者GetExecutingAssembly取得当前执行的Assembly 然后通过Assembly类的Location获取assembly的位置

但是使用Assembly的时候 可能会遇到权限方面的问题 同时Assembly GetCallingAssembly或者Assembly GetExecutingAssembly有可能得到的不是 exe文件的位置 在GAC中的添加了强名的Assembly 运行时是可以不必与 exe在同一目录的

NET的进程启动时 会创建AppDomain 所有的Assembly都被Load到某一个AppDomain中 而AppDomain中提供了SetupInformation属性 可以获取AppDomain启动时的一些信息 因此 可以通过调用AppDomain CurrentDomain SetupInformation ApplicationBase获取当前应用程序所在的路径

在通过以上方法取到所需的目录后 可以调用System IO Path的方法获取文件名 目录名 绝对路径等 停止对路径字符串的分析 而改用System IO Path类吧

lishixinzhi/Article/program/net/201311/11363

基目录就是基础目录相当于家目录,等于变量ORACLE_BASE,是oracle的默认路径;软件目录就是oracle代码的存放位置,等同于变量ORACLE_HOME系统变量数据库文件位置是放数据库的位置,可以随意指定,只要有空间和权限都可以

以上就是关于Mac的finder如何查看最基层目录,就像windows的目录:我的电脑/本地磁盘C/ 一样全部的内容,包括:Mac的finder如何查看最基层目录,就像windows的目录:我的电脑/本地磁盘C/ 一样、c#winform程序,程序运行控制台有很多报错信息,怎么办、C#怎样获取项目的debug路径等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/10089828.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-05
下一篇 2023-05-05

发表评论

登录后才能评论

评论列表(0条)

保存