q = open("E:/111.txt", "a", encoding="UTF-8") line = str(q.read()) for x in line : if x.split(",")[4] == "测试" : line.strip(x) q.write(line)
时间: 2024-04-12 17:27:24 浏览: 133
您好!根据您的代码片段,它的功能是打开一个名为 "E:/111.txt" 的文件,并将内容追加到文件末尾。然后,它将读取文件的内容并将其存储在变量line中。接下来,它遍历line中的每个字符,并检查逗号分隔的第五个元素是否为 "测试"。如果是,则删除该行,并将更改后的内容写回文件中。
不过,我注意到您的代码有一些问题。首先,您应该在打开文件之后立即读取其内容,而不是在写入之前。其次,您需要使用文件对象的write()方法写入更改后的内容,而不是直接写入变量line。此外,使用strip()方法无法删除整行,它只能删除字符串两侧的空白字符。
以下是一个修正后的代码示例:
```
with open("E:/111.txt", "r", encoding="UTF-8") as file:
lines = file.readlines()
with open("E:/111.txt", "w", encoding="UTF-8") as file:
for line in lines:
if line.split(",")[4] != "测试":
file.write(line)
```
这段修正后的代码会先读取整个文件的内容,并将每一行存储在一个列表中。然后,它打开同一个文件以写入模式,并遍历列表中的每一行。如果该行的第五个元素不是 "测试",则将其写回文件中。
希望这可以帮助到您!如果您有任何其他问题,请随时提问。
相关问题
import jieba import jieba.analyse import wordcloud from wordcloud import WordCloud text1=open("text1.txt", "r", encoding="utf-8") line1= text1.read() LIST1=jieba.analyse.extract_tags(line1,10) text2=open("text2.txt", "r", encoding="utf-8") line2= text2.read() LIST2=jieba.analyse.extract_tags(line2,10) a=[x for x in LIST1 if x in LIST2] wc = WordCloud(background_color='white', font_path='D:\Program Files (x86)\Douyu\DYTool\data\Font\内海字体.ttf', width=1000, height=800, ) wc.generate(str(a)) wc.to_file("10.png")
这段代码的作用是读取两个文本文件(text1.txt和text2.txt),使用 jieba.analyse 模块对两个文本进行关键词提取,提取出的关键词数量为10个,并将提取出来的两个文本的关键词列表进行交集操作,得到两个文本共同的关键词列表。然后使用 WordCloud 模块生成词云图,词云图的背景为白色,字体采用了内海字体,大小为1000x800,最后将生成的词云图保存为10.png文件。
#第二次作业 #26 #(1) lst=[1,2,3,4,5] square=map(lambda x:x*x,lst) print(list(square)) #(2) even=filter(lambda x:x%2==0,lst) print(list(even)) #27 #(1) file1=open("E:/大一/python与程序设计/file1.txt","r") content1=file1.read() lst1=content1.split() num=list(map(int,lst1)) allnum=sum(num) print(allnum) file1.close() #(2) file1=open("E:/大一/python与程序设计/file1.txt","r") content=[] for i in range(1,4): l=file1.readline() num= list(map(int, l.split())) num.sort() strs=" ".join(list(map(str,num))) strs2=strs+"\n" content.append(strs2) file2=open("E:/大一/python与程序设计/file2.txt","w") file2.writelines(content) file2.close() file1.close() #(3) file1=open("E:/大一/python与程序设计/file1.txt","r") content=file1.readlines() print(len(content)) #28 from datetime import datetime as dt file3=open("E:/大一/python与程序设计/file3.txt",'r',encoding='utf-8') line1=file3.readline() content=[] for i in range(1,4): l=file3.readline().split() content.append(l) col1=[content[0][0],content[1][0],content[2][0]] col2=[content[0][1],content[1][1],content[2][1]] col3=[content[0][2],content[1][2],content[2][2]] col4=[content[0][3],content[1][3],content[2][3]] day_formate="%H:%M:%S" Time=[] Code=[] Price=[] Volume=[] for t in col1: Time.append(dt.strptime(t,day_formate)) for c in col2: Code.append(str(c)) for p in col3: Price.append(float(p)) for v in col4: Volume.append(int(v)) file3.close() #29 #(1) mean=lambda x,y,z:(x+y+z)/3 #(2) def mean(*num): if bool(num)==0: return None else: return sum(num)/len(num) #30 def fibo(n): if n==1 or n==2: return 1 else: return fibo(n-1)+fibo(n-2) #31 from math import sqrt class Point(): def __init__(self,x,y): self.x=x self.y=y class Line(Point): def __init__(self,p1,p2): self.p1=p1 self.p2=p2 def lenth(self): lenth=sqrt((self.p1.x-self.p2.x)**2+(self.p1.y-self.p2.y)**2) return lenth def slope(self): if self.p1.x==self.p2.x: return None else: k=(self.p1.y-self.p2.y)/(self.p1.x-self.p2.x) return k def __repr__(self): return ((self.p1),(self.p2)) p1=Point(2,3) p2=Point(5,9) line=Line(p1,p2) l_line=line.lenth() k_line=line.slope() print(f"起点(2,3)到止点(5,9)的线段长度为{l_line},斜率为{k_line}") #32 class Point(): #(1) def __init__(self,x=0,y=0): self.x=x self.y=y #(2) def trans(self): return (self.y,self.x) #(3) def show(self): return print(f"该点坐标为({self.x},{self.y})") #(4) p1=Point(1,2) p1.trans() p1.show() p2=Point(3,5) p2.trans() p2.show()
对于你的代码,我进行了一些修改和注释,以便更好地理解。请查看以下代码:
# 26
# (1) 计算列表中每个元素的平方
lst = [1, 2, 3, 4, 5]
square = map(lambda x: x * x, lst)
print(list(square))
# (2) 过滤出列表中的偶数
even = filter(lambda x: x % 2 == 0, lst)
print(list(even))
# 27
# (1) 读取文件中的数字,并计算它们的总和
file1 = open("E:/大一/python与程序设计/file1.txt", "r")
content1 = file1.read()
lst1 = content1.split()
num = list(map(int, lst1))
allnum = sum(num)
print(allnum)
file1.close()
# (2) 读取文件中的数字,并将每行数字进行排序后写入新文件
file1 = open("E:/大一/python与程序设计/file1.txt", "r")
content = []
for i in range(1, 4):
l = file1.readline()
num = list(map(int, l.split()))
num.sort()
strs = " ".join(list(map(str, num)))
strs2 = strs + "\n"
content.append(strs2)
file2 = open("E:/大一/python与程序设计/file2.txt", "w")
file2.writelines(content)
file2.close()
file1.close()
# (3) 读取文件中的行数
file1 = open("E:/大一/python与程序设计/file1.txt", "r")
content = file1.readlines()
print(len(content))
# 28
# 从文件中读取数据,并按照列进行解析
from datetime import datetime as dt
file3 = open("E:/大一/python与程序设计/file3.txt", 'r', encoding='utf-8')
line1 = file3.readline()
content = []
for i in range(1, 4):
l = file3.readline().split()
content.append(l)
# 将字符串时间转换为datetime类型
col1 = [content[0][0], content[1][0], content[2][0]]
day_formate = "%H:%M:%S"
Time = [dt.strptime(t, day_formate) for t in col1]
# 将字符串转换为其他类型
col2 = [content[0][1], content[1][1], content[2][1]]
Code = [str(c) for c in col2]
col3 = [content[0][2], content[1][2], content[2][2]]
Price = [float(p) for p in col3]
col4 = [content[0][3], content[1][3], content[2][3]]
Volume = [int(v) for v in col4]
file3.close()
# 29
# (1) 求三个数的平均值
mean = lambda x, y, z: (x + y + z) / 3
# (2) 求任意数量的数的平均值
def mean(*num):
if bool(num) == 0:
return None
else:
return sum(num) / len(num)
# 30
# 计算斐波那契数列的第n项
def fibo(n):
if n == 1 or n == 2:
return 1
else:
return fibo(n - 1) + fibo(n - 2)
# 31
# 定义Point和Line类,并计算线段长度和斜率
from math import sqrt
class Point():
def __init__(self, x, y):
self.x = x
self.y = y
class Line(Point):
def __init__(self, p1, p2):
self.p1 = p1
self.p2 = p2
def length(self):
length = sqrt((self.p1.x - self.p2.x) ** 2 + (self.p1.y - self.p2.y) ** 2)
return length
def slope(self):
if self.p1.x == self.p2.x:
return None
else:
k = (self.p1.y - self.p2.y) / (self.p1.x - self.p2.x)
return k
def __repr__(self):
return ((self.p1), (self.p2))
p1 = Point(2, 3)
p2 = Point(5, 9)
line = Line(p1, p2)
l_length = line.length()
k_line = line.slope()
print(f"起点(2,3)到止点(5,9)的线段长度为{l_length},斜率为{k_line}")
# 32
# (1) 定义一个Point类,包含x和y坐标
class Point():
def __init__(self, x=0, y=0):
self.x = x
self.y = y
# (2) 定义一个trans()函数,将坐标轴进行转换
def trans(self):
return (self.y, self.x)
# (3) 定义一个show()函数,打印出点的坐标
def show(self):
return print(f"该点坐标为({self.x},{self.y})")
p1 = Point(1, 2)
p1.trans()
p1.show()
p2 = Point(3, 5)
p2.trans()
p2.show()
阅读全文