我有一个txt文件,其中包含以下方式的数据:
13
56
9
32
99
74
2
不同文件中的每个值。我创建了三个函数:
第一个是交换值
def swap(lst,x,y):
temp = lst[x]
lst[x] = lst[y]
lst[y] = temp
,第二个功能是对值进行排序:
def selection_sort(lst):
for x in range(0,len(lst)-1):
print(lst)
swap(lst,x,findMinFrom(lst[x:])+ x)
第三个功能是从列表中找到最小值:
def findMinFrom(lst):
minIndex = -1
for m in range(0,len(lst)):
if minIndex == -1:
minIndex = m
elif lst[m] < lst[minIndex]:
minIndex = m
return minIndex
现在,我如何从包含数字的文件中读取并打印出它们的排序?
提前致谢!
我用过:
def main():
f = []
filename = input("Enter the file name: ")
for line in open(filename):
for eachElement in line:
f += eachElement
print(f)
selectionSort(f)
print(f)
main()
但仍然无法正常工作!有什么帮助吗?
答案 0 :(得分:3)
优秀的程序员不会重新发明轮子并使用大多数现代语言标准的排序程序。你可以这样做:
with open('input.txt') as fp:
for line in sorted(fp):
print(line, end='')
打印按字母顺序排列的行(作为字符串)。并且
with open('input.txt') as fp:
for val in sorted(map(int, fp)):
print(val)
以数字排序。
答案 1 :(得分:0)
读取文件中的所有行:
f = open('test.txt')
your_listname = list(f)
排序和打印
selection_sort(output_listname)
print(output_listname)
您可能需要在排序/打印前删除换行符
stripped_listname=[]
for i in your_listname:
i = i.strip('\n')
stripped_listname.append(i)
您可能还希望从排序功能中取出print语句,以便在排序时不会多次打印列表。