我从第二个问题开始,因为它很短。只需在行尾使用分号;,不会返回任何值!
CSV.write(file, table);
但是,如果您想确定 ans 没有任何价值,请在末尾添加 nothing:
CSV.write(file, table);nothing;
如果你愿意,你可以把它打包成一个函数:
function my_write(file, table)
CSV.write(file, table)
nothing
end
或者,如果您想要一个单行代码,请将其包装成 lambda:
julia> (() -> begin;CSV.write("file.csv", df);nothing;end)()
julia> ans == nothing
true
在每种情况下都不会观察到副作用(返回值)。
第一个问题比较棘手。用于在文件中存储数据的可能格式显然需要取决于数据的格式。基本上,Julia 最常见的选项包括(我从最通用的选项开始,最后是最具体的选项):
- 通过
serialize命令序列化
- 通过
BSON.jl 包的二进制JSON
- JSON 通过
JSON.jl 或稍新的JSON3.jl 包(从今天开始都是不错的选择)
-
JSONTables.jl 用于存储为 JSON 的表格数据
-
DelimitedFiles 用于存储 Arrays
-
CSV.jl 用于存储 DataFrames
现在,特定套餐的选择将取决于您的目标。序列化是杀手级机制 - 最快和最通用的。任何对象都可以在尽可能短的时间内以这种方式存储。没有什么是没有代价的——当你更新 Julia 版本或你的包时,你可能无法读回你的对象。所以它是为短期存储而设计的。
中间是基于 JSON 的存储系统。基本上,所有内容都可以存储为 JSON,以后可以用 Julia 或其他编程语言读取。基于文本的 JSON 也可以在简单的文本编辑器中打开。
最后,CSV.jl 和Serialization 可以分别用于表和数组。但是,将DataFrame 转换为Array 或将Array 转换为DataFrame 很容易:
julia> df = DataFrame(a=1:3, b=rand(3),c=["a","b","c"])
3×3 DataFrame
│ Row │ a │ b │ c │
│ │ Int64 │ Float64 │ String │
├─────┼───────┼──────────┼────────┤
│ 1 │ 1 │ 0.440796 │ a │
│ 2 │ 2 │ 0.44232 │ b │
│ 3 │ 3 │ 0.282064 │ c │
julia> Matrix(df)
3×3 Array{Any,2}:
1 0.440796 "a"
2 0.44232 "b"
3 0.282064 "c"
您可以看到,在此过程中唯一丢失的是类型信息,如果您通过DelimitedFiles 导出数据,这并不重要。
其他方式的转换也很简单:
julia> rand(3,3) |> Tables.table |> DataFrame
3×3 DataFrame
│ Row │ Column1 │ Column2 │ Column3 │
│ │ Float64 │ Float64 │ Float64 │
├─────┼──────────┼───────────┼──────────┤
│ 1 │ 0.326649 │ 0.0278134 │ 0.111221 │
│ 2 │ 0.769378 │ 0.996156 │ 0.237821 │
│ 3 │ 0.802094 │ 0.726497 │ 0.619013 │
总之,如您所见,一切都可以在 Julia 中完成。