文件读取的基本操作
file1 = open('/Users/baoxiao/Desktop/test/score.txt', 'r',encoding='utf-8')
# readlines() 会从txt文件取得一个列表,列表中的每个字符串就是scores.txt中的每一行。
# 而且每个字符串后面还有换行的\n符号。
filelines = file1.readlines()
file1.close()
for i in filelines:
# 本身字符串自带换行,但读取时任然是一串连接的字符,
data=i.split()
print(data)
Python使用open()函数读取文件,这里使用readline()将文件中每一行当做一个元素存入列表,然后遍历列表,使用split()来分隔每一个元素并输出,这样将返回i个列表,每个列表是原来那一行的内容。
同样还有join()方法,合并元素内容。
```python
a=['c','a','t']
b=''
print(b.join(a))
c='-'
print(c.join(a))
输出结果是
cat
c-a-t
```python
file1 = open('/Users/baoxiao/Desktop/test/score.txt', 'r', encoding='utf-8')
# readlines() 会从txt文件取得一个列表,列表中的每个字符串就是scores.txt中的每一行。
# 而且每个字符串后面还有换行的\n符号。
filelines = file1.readlines()
file1.close()
final_score=[]
for i in filelines:
# 本身字符串自带换行,但读取时任然是一串连接的字符,
data=i.split()
sum=0
for score in data[1:]:
sum=sum+int(score)
result=data[0]+str(sum)
print(result)
final_score.append(result)
winnner=open('/Users/baoxiao/Desktop/test/winner.txt','w',encoding='utf-8')
# 按行输入最终的结果
winnner.writelines(final_score)
winnner.close()
改进版对数据进行求和输出。
输出数据时,若没有原始文件,则自动生成原始文件,由于write()只可以写入一个字符串,而writelines()可以写入一个列表,为了匹配写入类型,使用writelines().
print('吴枫'.encode('utf-8'))
print('吴枫'.encode('gbk'))
print(b'\xe5\x90\xb4\xe6\x9e\xab'.decode('utf-8'))
print(b'\xce\xe2\xb7\xe3'.decode('gbk'))
print(type('吴枫'))
print(type(b'\xce\xe2\xb7\xe3'))
小玩具,十六进制和中文字符之间的装换
list_test = ['一弦一柱思华年。\n','只是当时已惘然。\n'] # 将要默写的诗句放在列表里。
with open ('/Users/baoxiao/Desktop/test/Test2_15/poem1.txt','r') as f:
lines = f.readlines()
print(lines)
with open('/Users/baoxiao/Desktop/test/Test2_15/poem1.txt','w') as new:
for line in lines:
if line in list_test: # 属于默写列表中的句子,将其替换成横线。
new.write('____________。\n')
else:
new.write(line)
第一个脚本,用于获取文件,并修改文件。改进版就可以制作成古诗默写试卷,每一次只要更改list_test里的内容即可,下一个思考点,新建一个文件,读取为列表,然后随机选取默写的内容并生成新的试卷。