我有一个包含以下内容的文本文件:
player1
10
player2
13
player3
60
这些是球员姓名和得分。例如,玩家 1 的得分为 10,玩家 2 的得分为 13,依此类推。我想按分数对文本文件进行排序。例如:
player3 60
player2 13
player1 10
您需要将文件读入数组,进行一些操作,然后写回文件。假设源文件包含如图所示的行对。
首先将文件的行读入数组File#readlines(注意,chomp: true
用于剥离"\n"
)。
data = File.readlines('score.txt', chomp: true)
#=> ["player1", "10", "player2", "13", "player3", "60"]
拥有数组后,将每两个元素(Enumerable#each_slice)分组并按第二个元素(被视为整数.to_i
)排序(Enumerable#sort_by)。注意-
颠倒排序顺序的符号。作为嵌套数组 ( Array#join )中的一对元素的最后一个操作map
( Enumerable#map ) :join
score_sorted = data.each_slice(2).sort_by { |_, score| -score.to_i}.map{ |ary| ary.join(' ') }
#=> ["player3 60", "player2 13", "player1 10"]
最后,将数组写回文件(File#open):
File.open("score_sorted.txt", "w+") { |f| f.puts score_sorted }
这种情况的基本实现可能是这样的:
def main
file = File.new("score.txt", "r")
players = Array.new
score = Array.new
number_regex = /\A[-+]?[0-9]*\.?[0-9]+\Z/
file.each_line do |line|
if(line.match(number_regex))
score << line.delete(" \t\r\n")
else
players << line.delete(" \t\r\n")
end
end
file.close
result = Hash.new
i = 0
while i < players.length
result[players[i]] = score[i]
i += 1
end
print_score(result)
end
def print_score(hash)
hash.each do |key,value|
puts key + ": " + value
end
end
main
但是,我警告!这只是一个基本的实现。这个方案有一些副作用,比如如果数据的数据序列被破坏了,这个算法就会停止工作。
player1
10
player2
player3
60
要实现一个完全有效的解决方案,您需要在读取每一行时检查下一行并验证它是否包含所需值的内容。如果序列被破坏,并且在“playerN”的值之后得分数不去,那么在这种情况下将它们的缺失视为 0。通常,在这种情况下创建一个整体解决方案并不是一件容易的事。而为了选择最优解,其实你并没有提供足够的数据。.txt 帐户是从哪里记录的?是否可以更改录音的来源?等等