Tabela w języku Lua to zestaw mapowań klucz-wartość z unikalnymi kluczami. Pary są przechowywane w dowolnej kolejności i dlatego tabela nie jest w żaden sposób sortowana.
Co można zrobić, to iterować nad tabelą w dowolnej kolejności. Podstawowy pairs
nie daje żadnej gwarancji kolejności, w jakiej klucze są odwiedzane. Tutaj jest dostosowana wersja pairs
, który nazwałem spairs
ponieważ iteracje nad stołem w posortowanych:
function spairs(t, order)
-- collect the keys
local keys = {}
for k in pairs(t) do keys[#keys+1] = k end
-- if order function given, sort by it by passing the table and keys a, b,
-- otherwise just sort the keys
if order then
table.sort(keys, function(a,b) return order(t, a, b) end)
else
table.sort(keys)
end
-- return the iterator function
local i = 0
return function()
i = i + 1
if keys[i] then
return keys[i], t[keys[i]]
end
end
end
Oto przykład wykorzystania takiej funkcji:
HighScore = { Robin = 8, Jon = 10, Max = 11 }
-- basic usage, just sort by the keys
for k,v in spairs(HighScore) do
print(k,v)
end
--> Jon 10
--> Max 11
--> Robin 8
-- this uses an custom sorting function ordering by score descending
for k,v in spairs(HighScore, function(t,a,b) return t[b] < t[a] end) do
print(k,v)
end
--> Max 11
--> Jon 10
--> Robin 8
możliwym duplikatu [ kopiowanie danych z tabeli do kolejnej z zamówieniem] (http://stackoverflow.com/questions/5153642/copying-data-from-table-to-antoher-with-order) – finnw
Tabela nie jest uporządkowaną tablicą lub czymś. Nie ma zamanifestowanej kolejności. – texasbruce