将 FOR 循环的结果写入 .txt 文件 python
Write to .txt file the results from FOR looping in python
我的程序是根据该输入值从.txt 文件中搜索上限值和下限值。
def find_closer():
file = 'C:/.../CariCBABaru.txt'
data = np.loadtxt(file)
x, y = data[:,0], data[:,1]
print(y)
for k in range(len(spasi_baru)):
a = y #[0, 20.28000631, 49.43579604, 78.59158576, 107.7473755, 136.9031652, 166.0589549,
176.5645474, 195.2147447]
b = spasi_baru[k]
# diff_list = []
diff_dict = OrderedDict()
if b in a:
b = input("Number already exists, please enter another number ")
else:
for x in a:
diff = x - b
if diff < 0:
# diff_list.append(diff*(-1))
diff_dict[x] = diff*(-1)
else:
# diff_list.append(diff)
diff_dict[x] = diff
#print("diff_dict", diff_dict)
# print(diff_dict[9])
sort_dict_keys = sorted(diff_dict.keys())
#print(sort_dict_keys)
closer_less = 0
closer_more = 0
#cl = []
#cm = []
for closer in sort_dict_keys:
if closer < b:
closer_less = closer
else:
closer_more = closer
break
#cl.append(closer_less == len(spasi_baru) - 1)
#cm.append(closer_more == len(spasi_baru) - 1)
print(spasi_baru[k],": lower value=", closer_less, "and upper
value =", closer_more)
data = open('C:/.../Batas.txt','w')
text = "Spasi baru:{spasi_baru}, File: {closer_less}, line:{closer_more}".format(spasi_baru=spasi_baru[k], closer_less=closer_less, closer_more=closer_more)
data.write(text)
data.close()
print(spasi_baru[k],": lower value=", closer_less, "and upper value =", closer_more)
find_closer()
结果图片在这里1
然后,我想将这些结果写入文件(txt/csv 没问题)成行和列序列。但是我遇到的问题是,文件只包含一行或在终端中写入最后一个值输出,如下所示,
Spasi baru:400, File: 399.3052727, line: 415.037138
有什么建议可以帮助解决我的问题吗?我花了几个小时尝试任何不同的代码算法。我正在使用 Python 3.7
原因是因为你在循环中一遍又一遍地覆盖同一个文件,所以它只会保留最后一次交互。寻找在不覆盖文件的情况下保存文件的方法。
‘r’ – 只读文件时使用的读取模式
‘w’ – 写入模式,用于编辑和写入新信息到文件(激活此模式时将删除任何现有的同名文件)
‘a’——追加模式,用于在文件末尾追加新数据;即新信息自动修改到最后
‘r+’ – 特殊读写模式,用于处理文件时的两种操作
最好的解决方案是在尝试追加到同一个测试文件时使用 w+ 或 a+ 模式。
而不是这样做:
data = open('C:/.../Batas.txt','w')
这样做:
data = open('C:/.../Batas.txt','w+')
or
data = open('C:/.../Batas.txt','a+')
我的程序是根据该输入值从.txt 文件中搜索上限值和下限值。
def find_closer():
file = 'C:/.../CariCBABaru.txt'
data = np.loadtxt(file)
x, y = data[:,0], data[:,1]
print(y)
for k in range(len(spasi_baru)):
a = y #[0, 20.28000631, 49.43579604, 78.59158576, 107.7473755, 136.9031652, 166.0589549,
176.5645474, 195.2147447]
b = spasi_baru[k]
# diff_list = []
diff_dict = OrderedDict()
if b in a:
b = input("Number already exists, please enter another number ")
else:
for x in a:
diff = x - b
if diff < 0:
# diff_list.append(diff*(-1))
diff_dict[x] = diff*(-1)
else:
# diff_list.append(diff)
diff_dict[x] = diff
#print("diff_dict", diff_dict)
# print(diff_dict[9])
sort_dict_keys = sorted(diff_dict.keys())
#print(sort_dict_keys)
closer_less = 0
closer_more = 0
#cl = []
#cm = []
for closer in sort_dict_keys:
if closer < b:
closer_less = closer
else:
closer_more = closer
break
#cl.append(closer_less == len(spasi_baru) - 1)
#cm.append(closer_more == len(spasi_baru) - 1)
print(spasi_baru[k],": lower value=", closer_less, "and upper
value =", closer_more)
data = open('C:/.../Batas.txt','w')
text = "Spasi baru:{spasi_baru}, File: {closer_less}, line:{closer_more}".format(spasi_baru=spasi_baru[k], closer_less=closer_less, closer_more=closer_more)
data.write(text)
data.close()
print(spasi_baru[k],": lower value=", closer_less, "and upper value =", closer_more)
find_closer()
结果图片在这里1
然后,我想将这些结果写入文件(txt/csv 没问题)成行和列序列。但是我遇到的问题是,文件只包含一行或在终端中写入最后一个值输出,如下所示,
Spasi baru:400, File: 399.3052727, line: 415.037138
有什么建议可以帮助解决我的问题吗?我花了几个小时尝试任何不同的代码算法。我正在使用 Python 3.7
原因是因为你在循环中一遍又一遍地覆盖同一个文件,所以它只会保留最后一次交互。寻找在不覆盖文件的情况下保存文件的方法。
‘r’ – 只读文件时使用的读取模式
‘w’ – 写入模式,用于编辑和写入新信息到文件(激活此模式时将删除任何现有的同名文件)
‘a’——追加模式,用于在文件末尾追加新数据;即新信息自动修改到最后
‘r+’ – 特殊读写模式,用于处理文件时的两种操作
最好的解决方案是在尝试追加到同一个测试文件时使用 w+ 或 a+ 模式。
而不是这样做:
data = open('C:/.../Batas.txt','w')
这样做:
data = open('C:/.../Batas.txt','w+')
or
data = open('C:/.../Batas.txt','a+')