Я пробовал всевозможные способы упорядочить текстовый файл в алфавитном порядке по фамилии. Фамилия в настоящее время читается как второй столбец каждой строки разделения. Я могу без проблем сортировать по столбцу. Я пытаюсь поставить last.sort () или использовать отсортированный (myList), но это не работает. Я даже пробовал импортировать itemgetter. Пожалуйста помоги! Фотографии результатов ... предыдущие результаты с отсортированным столбцом ... Изображение текстового файла
ИНФОРМАЦИЯ О TXT-ФАЙЛЕ: 654, Джонс, 1,18: 03 733, Смит, 3,18: 09 394, Джексон, 4,18: 22 876, Коул, 1,18: 23 555, Крус, 5,18: 28 741, Мартинес, 2,18: 33 499, Дэвис, 2,18: 36 338, Тупой, 3,18: 44 632, Паттон, 5,18: 45 712, Джойс, 4,18: 49 112, Сапожник, 1,18: 55 321, Смарт, 5,18: 58 564, Любовь, 2,19: 01 843, Роща, 4,19: 05 933, Ветчина, 3,19: 10
with open("Race_Results_Sample.txt", "r")as myList:
myList= myList.read().split()
sorted(myList, key=lambda kv: kv[1])
for line in myList:
num, last, org, time = line.split(",")
print num, last, org, time
Первоначально вы разделяете пробелами, а затем разделяете запятыми. Вероятно, в каждом случае вам нужно будет сделать один и тот же тип разделения. Попробуйте сменить .split() на .split(',').
Я попытался изменить первый .split (), чтобы включить ',', но это ошибки: IndexError: индекс строки вне допустимого диапазона






Попробуйте разобрать текст в 2d-список, что-то вроде
with open("test.txt", "r")as myList:
myList = myList.read()
myList = [l.split(",") for l in myList.splitlines()]
myList = sorted(myList, key=lambda kv: kv[1])
for line in myList:
num, last, org, time = line
print num, last, org, time
Разделите на разрыв строки, а затем снова на каждую строку через запятую.
Это прекрасно работает !!! Огромное спасибо!! Я весь день пытался заставить это работать.
Можете ли вы включить образец первых десяти строк вашего текстового файла?