首页 > 解决方案 > 将 dict 中的键值对分配给 DataDrame 在 Julia 1.1 中不起作用

问题描述

我正在尝试DataFrameDictJulia 1.1 中构建 a。字典中的键是列名,值是包含列应该具有的值的向量。我虽然它会像

df = DataFrame()
for (key,value) in datadict
  df[key] = value
end

但这会抛出一个ERROR: LoadError: MethodError: no method matching setindex!(::DataFrame, ::Array{String,1}, ::String). 我没有直接使用 tha 变量key,而是尝试将符号:key作为列名传递,如 in df[:key] = value,这会删除错误消息,但仅将第一个键值对作为列插入到数据框中,并key作为列名:

10×1 DataFrame
│ Row │ key        │
│     │ String     │
├─────┼────────────┤
│ 1   │ 2019-03-04 │
│ 2   │ 2019-03-05 │
│ 3   │ 2019-03-06 │
│ 4   │ 2019-03-07 │
│ 5   │ 2019-03-08 │
│ 6   │ 2019-03-09 │
│ 7   │ 2019-03-10 │
│ 8   │ 2019-03-11 │
│ 9   │ 2019-03-12 │
│ 10  │ 2019-03-13 │

这显然不是我想要的。我在这里做错了什么?

标签: dataframedictionaryjuliadata-conversion

解决方案


这段代码应该可以工作:

using DataFrames
datadict = Dict(1 => ["2019-03-04", "2019-03-04"], 2 => ["1996-26-12", "1996-25-12"])
df = DataFrame()
for (key, value) in datadict
       df[Symbol(key)] = value
end

您必须使用 . 创建密钥的符号Symbol(key)


推荐阅读