2017-01-30 85 views
0

我试图找出为什么我不断收到以下错误: enter image description here红宝石未定义的方法`[]”的零:NilClass(NoMethodError)错误

从下面的代码:

def information_transfer() 
    file_contents = CSV.read("test.csv", col_sep: ",", encoding: "ISO8859-1") 
    file_contents2 = CSV.read("applicantinfo.csv", col_sep: ",", encoding:"ISO8859-1") 
    arraysize = file_contents.length 
    arraysize1 = file_contents2.length 
    for i in 1..arraysize 
    for x in 1..arraysize1 
     if file_contents[i][0] == file_contents2[x][0] 
     CSV.open("language_output.csv", "wb") do |csv| 
      csv << [file_contents[i][0], file_contents[i][1], file_contents[i][2],file_contents[i][3], file_contents[i][4], 
      file_contents[i][5], file_contents[i][6], file_contents[i][7], file_contents[i][8],file_contents[i][9], 
      file_contents[i][10], file_contents[i][11], file_contents[i][12], file_contents[i][13], file_contents[i][14], 
      file_contents[i][15], file_contents[i][16], file_contents[i][17], file_contents[i][18], file_contents2[i][24],file_contents2[i][25], 
      file_contents2[i][26],file_contents2[i][27], file_contents2[i][28], file_contents2[i][29], file_contents2[i][30], file_contents2[i][31], file_contents2[i][32], file_contents2[i][33]] 
     end 
    end 
    end 
end 
end 

我基本上试图把两个单独的.csv文件合并到一起。我有两个数组(file_contents和file_contents2),它们正在读取各个csv文件并将其内容存储在数组中。出于某种原因,我得到了我的if语句的语法错误。我希望有人能帮我弄清楚为什么我写的if语句是无效的。我想它会是。任何帮助表示赞赏。谢谢!

+1

能否请您点的行号哪一个是线:27 –

+0

它在你的'file_contents的一个破[I] [5]'好像'file_contents [I]'是零某处 –

+0

大家好,感谢所有的帮助!你们都帮我弄明白了!我很感激。 – John123

回答

1

好像的file_contents一个或file_contents2是空的。

如果您不想在该特定行上引发错误,则可以跳过循环。

next if file_contents[i].blank? || file_contents2[i].blank? 
if file_contents[i][0] == file_contents2[x][0] 
1

其中一个阵列file_contentsfile_contents2可能为空。输出两者,以及在您的if声明之前打印file_contents[i][0]file_contents2[x][0]

你可以做一个简单的变化,应该工作:

for i in 0..arraysize for x in 0..arraysize1

,加入一个错误检查:

if !file_contents[i].blank? and !file_contents2[x].blank? and file_contents[i][0] == file_contents2[x][0]

1
for i in 1..arraysize 
    for x in 1..arraysize1 

数组索引从0到长度− 1在Ruby中;代之以在0...arraysize中循环。

如果file_contents2[i]可以或应该写成file_contents2[x],你可以在阵列内容循环直接:

for a in file_contents 
    for b in file_contents2 

,并使用切片来获得连续的数组元素到另一个数组:

def information_transfer() 
    file_contents = CSV.read("test.csv", col_sep: ",", encoding: "ISO8859-1") 
    file_contents2 = CSV.read("applicantinfo.csv", col_sep: ",", encoding: "ISO8859-1") 
    for a in file_contents 
    for b in file_contents2 
     if a[0] == b[0] 
     CSV.open("language_output.csv", "wb") do |csv| 
      csv << a[0..18] + b[24..33] 
     end 
     end 
    end 
    end 
end 

如果您试图一对一地加入这两个文件,您可以通过将密钥放入哈希中来更有效地完成此操作。你也可能不打算每次重新打开输出文件。

def information_transfer() 
    file_contents = CSV.read("test.csv", col_sep: ",", encoding: "ISO8859-1") 
    file_contents2 = CSV.read("applicantinfo.csv", col_sep: ",", encoding: "ISO8859-1") 

    h = Hash[file_contents.collect { |row| [row[0], row] }] 

    CSV.open("language_output.csv", "wb") do |csv| 
    for b in file_contents2 
     a = h[b[0]] 
     csv << a[0..18] + b[24..33] 
    end 
    end 
end 
相关问题