草庐IT

Julia 文件(File)读写

runoob 2023-04-07 原文

Julia 文件(File)读写

Julia 提供了一些基本的函数来处理文件:

  • open() - 打开文件
  • read() - 读取文件内容
  • close() - 关闭文件

从文件读取或者写入数据需要使用文件句柄。

文件句柄其实就是一个指针,指针就是指向文件中的某个位置。

从一个文件读取数据,应用程序首先要调用操作系统函数并传送文件名,并选一个到该文件的路径来打开文件,打开文件的函数取回一个顺序号,即文件句柄(file handle),该文件句柄对于打开的文件是唯一的识别依据。

open() 函数

Julia 可以使用 open() 函数打开一个文件,该函数返回文件句柄:

语法格式:

open(filename, mode)

filename 为文件名,mode 为读写模式,可以是以下值:

mode(模式) 描述 关键词
r read none
w 写入、创建、截断 write = true
a 写入、创建、追加 append = true
r+ 读取, 写入 read = true, write = true
w+ 读取, 写入、创建、截断 truncate = true, read = true
a+ 读取, 写入、创建、写入、创建、追加 append = true, read = true
# Windows 打开文件
foo = open("D://runoob-test//julia//runoob-file.txt")

# Linux 或 Mac 打开文件 
foo = open("./runoob-test/julia/runoob-file.txt")

close() 函数

在对文件操作完成后,我们需要对文件进行关闭操作,不然会造成资源泄露等问题,关闭文件使用 close() 函数:

# 关闭上面代码中打开文件返回的 foo 句柄
close(foo)

在 Julia 中,我们建议任何文件处理函数包装在 do 语句块中,将文件处理函数包装在 do 语句块中的优点是,当该语句块执行完成时,打开的文件将自动关闭,就是会自动调用 close() 函数,如下所示:

实例

open("./runoob-test/julia/runoob-file.txt") do file
   # 执行文件操作
end

以上代码不需要调用 close() 函数,因为它会自动 close() 函数来关闭文件。

接下来我们创建一个 test.jl 文件,代码如下:

test.jl 文件代码:

# 打开文件,如果文件不存在就创建 runoob-file.txt
io = open("runoob-file.txt", "w");

# 写入文件内容
write(io, "Hello world!\nRunoob Julia Test");

# 关闭文件
close(io);

执行以上代码:

$ julia test.jl

执行成功后,我们就在当前代码文件的目录下创建了一个 runoob-file.txt 文件,写入内容如下:

Hello world!
Runoob Julia Test

我们可以使用 do 语句,这样就不需要使用 close() 函数:

test.jl 文件代码:

open("runoob-file.txt", "w") do io
    write(io, "Hello world!\nRunoob Julia Test\n使用 do 语句")
end;

执行以上代码:

$ julia test.jl

执行成功后,我们就在当前代码文件的目录下创建了一个 runoob-file.txt 文件,写入内容如下:

Hello world!
Runoob Julia Test
使用 do 语句

实例

# 读取文件内容
txt = open("runoob-file.txt") do file
    read(file, String)
end;
# 输出
println(txt)

read() 函数

使用 read() 函数,我们可以读取文件的全部内容,例如:

txt = read(foo, String)

实例

# 打开文件
file = open("runoob-file.txt")

# 读取文件内容
txt = read(file, String)

# 关闭文件
close(file)

# 输出
println(txt)

执行以上代码,输出结果如下:

$ Julia test.jl
Hello world!
Runoob Julia Test

do 语句中使用 read() 函数:

open(filename) do file
    read(file, String)
end

实例

# 读取文件内容
txt = open("runoob-file.txt") do file
    read(file, String)
end;
# 输出
println(txt)

执行以上代码,输出结果如下:

$ julia test.jl
Hello world!
Runoob Julia Test

我们可以使用 readlines() 函数将文件内容按行放到数组中,语法如下:

readlines(io::IO=stdin; keep::Bool=false)
readlines(filename::AbstractString; keep::Bool=false)

实例

# 打开文件
file = open("runoob-file.txt")

# 读取文件内容
txt=readlines(file, keep=true)

# 关闭文件
close(file)

# 输出
println(txt)

执行以上代码,输出结果如下:

$ julia test.jl
["Hello world!\n", "Runoob Julia Test\n", "使用 do 语句"]

我们也可以使用 eachline() 函数逐行处理文件:

实例

# 打开文件
open("runoob-file.txt") do file
# 逐行读取文件内容
    for ln in eachline(file)
        # 输出字符串长度与字符串
        println("$(length(ln)), $(ln)")
    end
end

执行以上代码,输出结果如下:

$ julia test.jl
12, Hello world!
17, Runoob Julia Test
8, 使用 do 语句

我们也可以获取当前的行号:

实例

open("runoob-file.txt") do f
    # 设置行号
    line = 1
    while !eof(f)
       x = readline(f)
       println("$line $x")
       # 逐行递增
       line += 1
    end
 end

执行以上代码,输出结果如下:

$ julia test.jl
1 Hello world!
2 Runoob Julia Test
3 使用 do 语句

stat() 函数

stat() 函数用于获取文件的信息,格式如下:

stat(pathname) 

实例

for n in fieldnames(typeof(stat("runoob-file.txt")))
    println(n, ": ", getfield(stat("runoob-file.txt"),n))
end

执行以上代码,输出结果如下:

$ julia test.jl
desc: runoob-file.txt
device: 16777222
inode: 35345094
mode: 33188
nlink: 1
uid: 501
gid: 20
rdev: 0
size: 47
blksize: 4096
blocks: 8
mtime: 1.6524042534674733e9
ctime: 1.6524042534674733e9

abspath() 函数

abspath() 函数用于获取文件的绝对路径,可以映射列表中:

stat(pathname) 

实例

println(map(abspath, readdir()))

执行以上代码,输出结果如下:

["/Users/RUNOOB/runoob-test/.Rhistory", "/Users/RUNOOB/runoob-test/.vscode", 
...

更多函数

下表列出来处理文件的其他相关函数:

序号 函数及描述
1

cd(path)

切换当前目录

2

pwd()

获取当前目录

3

readdir(path)

返回当前目录的文件与目录列表。

4

abspath(path)

将当前目录的文件名生成绝对路径。

5

joinpath(str, str, ...)

从参数中组装路径名。

6

isdir(path)

判断提供的路径参数 path 是否是一个目录。

7

splitdir(path)

将路径拆分为目录名和文件名的元组。

8

splitdrive(path)

Windows 上将路径拆分为驱动器号部分和路径部分,在 Unix 系统上,第一个组件始终是空字符串。

9

splitext(path)

如果路径的最后一个组件包含一个点,则将路径拆分为点之前的所有内容以及包括点和点之后的所有内容。 否则,返回一个未修改的参数和空字符串的元组。

10

expanduser(path)

将路径开头的波浪字符 ~ 替换为当前用户的主目录。

11

normpath(path)

规范化路径,删除 "." 和 ".." 目录

12

realpath(path)

如果符号链接来规范化路径,并删除 "." 和 ".." 目录

13

homedir()

获取当前用户的主目录。

14

dirname(path)

获取路径参数 path 的目录部分

15

basename(path)

获取路径参数 path 的文件名部分。

有关Julia 文件(File)读写的更多相关文章

  1. ruby - 使用 RubyZip 生成 ZIP 文件时设置压缩级别 - 2

    我有一个Ruby程序,它使用rubyzip压缩XML文件的目录树。gem。我的问题是文件开始变得很重,我想提高压缩级别,因为压缩时间不是问题。我在rubyzipdocumentation中找不到一种为创建的ZIP文件指定压缩级别的方法。有人知道如何更改此设置吗?是否有另一个允许指定压缩级别的Ruby库? 最佳答案 这是我通过查看ruby​​zip内部创建的代码。level=Zlib::BEST_COMPRESSIONZip::ZipOutputStream.open(zip_file)do|zip|Dir.glob("**/*")d

  2. ruby - 其他文件中的 Rake 任务 - 2

    我试图在一个项目中使用rake,如果我把所有东西都放到Rakefile中,它会很大并且很难读取/找到东西,所以我试着将每个命名空间放在lib/rake中它自己的文件中,我添加了这个到我的rake文件的顶部:Dir['#{File.dirname(__FILE__)}/lib/rake/*.rake'].map{|f|requiref}它加载文件没问题,但没有任务。我现在只有一个.rake文件作为测试,名为“servers.rake”,它看起来像这样:namespace:serverdotask:testdoputs"test"endend所以当我运行rakeserver:testid时

  3. ruby-on-rails - 在 Rails 中将文件大小字符串转换为等效千字节 - 2

    我的目标是转换表单输入,例如“100兆字节”或“1GB”,并将其转换为我可以存储在数据库中的文件大小(以千字节为单位)。目前,我有这个:defquota_convert@regex=/([0-9]+)(.*)s/@sizes=%w{kilobytemegabytegigabyte}m=self.quota.match(@regex)if@sizes.include?m[2]eval("self.quota=#{m[1]}.#{m[2]}")endend这有效,但前提是输入是倍数(“gigabytes”,而不是“gigabyte”)并且由于使用了eval看起来疯狂不安全。所以,功能正常,

  4. ruby-on-rails - Rails 3 中的多个路由文件 - 2

    Rails2.3可以选择随时使用RouteSet#add_configuration_file添加更多路由。是否可以在Rails3项目中做同样的事情? 最佳答案 在config/application.rb中:config.paths.config.routes在Rails3.2(也可能是Rails3.1)中,使用:config.paths["config/routes"] 关于ruby-on-rails-Rails3中的多个路由文件,我们在StackOverflow上找到一个类似的问题

  5. ruby - 将差异补丁应用于字符串/文件 - 2

    对于具有离线功能的智能手机应用程序,我正在为Xml文件创建单向文本同步。我希望我的服务器将增量/差异(例如GNU差异补丁)发送到目标设备。这是计划:Time=0Server:hasversion_1ofXmlfile(~800kiB)Client:hasversion_1ofXmlfile(~800kiB)Time=1Server:hasversion_1andversion_2ofXmlfile(each~800kiB)computesdeltaoftheseversions(=patch)(~10kiB)sendspatchtoClient(~10kiBtransferred)Cl

  6. ruby - 如何将脚本文件的末尾读取为数据文件(Perl 或任何其他语言) - 2

    我正在寻找执行以下操作的正确语法(在Perl、Shell或Ruby中):#variabletoaccessthedatalinesappendedasafileEND_OF_SCRIPT_MARKERrawdatastartshereanditcontinues. 最佳答案 Perl用__DATA__做这个:#!/usr/bin/perlusestrict;usewarnings;while(){print;}__DATA__Texttoprintgoeshere 关于ruby-如何将脚

  7. ruby - 使用 Vim Rails,您可以创建一个新的迁移文件并一次性打开它吗? - 2

    使用带有Rails插件的vim,您可以创建一个迁移文件,然后一次性打开该文件吗?textmate也可以这样吗? 最佳答案 你可以使用rails.vim然后做类似的事情::Rgeneratemigratonadd_foo_to_bar插件将打开迁移生成的文件,这正是您想要的。我不能代表textmate。 关于ruby-使用VimRails,您可以创建一个新的迁移文件并一次性打开它吗?,我们在StackOverflow上找到一个类似的问题: https://sta

  8. Ruby 写入和读取对象到文件 - 2

    好的,所以我的目标是轻松地将一些数据保存到磁盘以备后用。您如何简单地写入然后读取一个对象?所以如果我有一个简单的类classCattr_accessor:a,:bdefinitialize(a,b)@a,@b=a,bendend所以如果我从中非常快地制作一个objobj=C.new("foo","bar")#justgaveitsomerandomvalues然后我可以把它变成一个kindaidstring=obj.to_s#whichreturns""我终于可以将此字符串打印到文件或其他内容中。我的问题是,我该如何再次将这个id变回一个对象?我知道我可以自己挑选信息并制作一个接受该信

  9. ruby-on-rails - rails : save file from URL and save it to Amazon S3 - 2

    从给定URL下载文件并立即将其上传到AmazonS3的更直接的方法是什么(+将有关文件的一些信息保存到数据库中,例如名称、大小等)?现在,我既不使用Paperclip,也不使用Carrierwave。谢谢 最佳答案 简单明了:require'open-uri'require's3'amazon=S3::Service.new(access_key_id:'KEY',secret_access_key:'KEY')bucket=amazon.buckets.find('image_storage')url='http://www.ex

  10. ruby - 如何使用 Ruby aws/s3 Gem 生成安全 URL 以从 s3 下载文件 - 2

    我正在编写一个小脚本来定位aws存储桶中的特定文件,并创建一个临时验证的url以发送给同事。(理想情况下,这将创建类似于在控制台上右键单击存储桶中的文件并复制链接地址的结果)。我研究过回形针,它似乎不符合这个标准,但我可能只是不知道它的全部功能。我尝试了以下方法:defauthenticated_url(file_name,bucket)AWS::S3::S3Object.url_for(file_name,bucket,:secure=>true,:expires=>20*60)end产生这种类型的结果:...-1.amazonaws.com/file_path/file.zip.A

随机推荐