您是否碰巧知道如何在 julia 脚本中获取 julia 脚本的路径?
本质上,我构建了一个名为 julia 的脚本someCode.jl,它位于名为repository.
当我运行时someCode.jl,我想创建一个output在文件夹中命名的输出文件夹repository并将一个文件a.txt放在文件夹中output。
使用绝对路径它可以正常工作,但我希望它对于将它放在不同路径中的人来说是可运行的,但我还没有找到正确的语法。
该pwd()命令返回安装 julia 的目录,在这种情况下是:"E:\\Users\\a\\AppData\\Local\\Julia-1.1.0"因此,我应该确保当前路径更新到运行脚本时所在的文件夹,或者获取脚本本身的位置, 在脚本代码中。这两种方法在 julia REPL 中都没有成功。
这是示例文件someCode.jl,我通过打开 Julia REPL 并输入:include("E:/someCode.jl")
open("c:/repository/output/a.txt", "w") do f
n1 = "Content of first line"
write(f, "$n1")
end
Run Code Online (Sandbox Code Playgroud)
如果存储库或输出文件夹尚不存在,则会引发错误:
ERROR: LoadError: SystemError: opening file "c:/repository/output/a.txt": No such file or directory
Stacktrace:
[1] #systemerror#43(::Nothing, ::Function, ::String, ::Bool) at .\error.jl:134
[2] systemerror at .\error.jl:134 [inlined]
[3] #open#309(::Nothing, ::Nothing, ::Nothing, ::Bool, ::Nothing, ::Function, ::String) at .\iostream.jl:283
[4] #open at .\none:0 [inlined]
[5] open(::String, ::String) at .\iostream.jl:339
[6] #open#310(::Base.Iterators.Pairs{Union{},Union{},Tuple{},NamedTuple{(),Tuple{}}}, ::Function, ::getfield(Main, Symbol("##7#8")), ::String, ::Vararg{String,N} where N) at .\iostream.jl:367
[7] open(::Function, ::String, ::String) at .\iostream.jl:367
[8] top-level scope at none:0
[9] include at .\boot.jl:326 [inlined]
[10] include_relative(::Module, ::String) at .\loading.jl:1038
[11] include(::Module, ::String) at .\sysimg.jl:29
[12] include(::String) at .\client.jl:403
[13] top-level scope at none:0
in expression starting at E:\someCode.jl:1
Run Code Online (Sandbox Code Playgroud)
所以我确保文件夹c:/repository/output存在,在名为“someLocalCode.jl and ran it withinclude("C:/repository/someLocalCode.jl")`的第二个脚本中放入:
open("c:/repository/output/a.txt", "w") do f
n1 = "Content of first line"
write(f, "$n1")
end
open("output/b.txt", "w") do f
n1 = "Content of first line"
write(f, "$n1")
end
open("/output/b.txt", "w") do f
n1 = "Content of first line"
write(f, "$n1")
end
#include("C:/repository/test.jl")
Run Code Online (Sandbox Code Playgroud)
当单独测试时,两者output/b.txt和/output/b.txt产生(本质上)相同的本质:
ERROR: LoadError: SystemError: opening file "/output/b.txt": No such file or directory
Stacktrace:
[1] #systemerror#43(::Nothing, ::Function, ::String, ::Bool) at .\error.jl:134
[2] systemerror at .\error.jl:134 [inlined]
[3] #open#309(::Nothing, ::Nothing, ::Nothing, ::Bool, ::Nothing, ::Function, ::String) at .\iostream.jl:283
[4] #open at .\none:0 [inlined]
[5] open(::String, ::String) at .\iostream.jl:339
[6] #open#310(::Base.Iterators.Pairs{Union{},Union{},Tuple{},NamedTuple{(),Tuple{}}}, ::Function, ::getfield(Main, Symbol("##15#16")), ::String, ::Vararg{String,N} where N) at .\iostream.jl:367
[7] open(::Function, ::String, ::String) at .\iostream.jl:367
[8] top-level scope at none:0
[9] include at .\boot.jl:326 [inlined]
[10] include_relative(::Module, ::String) at .\loading.jl:1038
[11] include(::Module, ::String) at .\sysimg.jl:29
[12] include(::String) at .\client.jl:403
[13] top-level scope at none:0
in expression starting at C:\repository\someLocalCode.jl:6
Run Code Online (Sandbox Code Playgroud)
而绝对路径确实起作用。
以下是选项:
@__DIR__ 宏扩展为带有包含宏调用的文件目录的绝对路径的字符串@__FILE__ 宏扩展为包含宏调用的文件路径的字符串PROGRAM_FILE 包含从命令行传递给 Julia 的脚本名称的常量