class DataInit: def __init__(self,fileURL,testEnv,testAccount,testUrlList) -> None: self.fileURL = fileURL self.testEnv=testEnv self.account=testAccount self.UrlList=testUrlList def Initdata(self): with open(self.fileURL,'r') as f: data = f.readline() # 测试环境 if data.split(":",1)[0]!='测试环境': print("未找到测试环境,请检查datainit.txt文件") return else: self.testEnv= data.split(":",1)[0] print(self.testEnv) self.testEnv = data.split(":",1)[1] print(self.testEnv) data = f.readline() i=0 for line in f.readlines(): line = line.strip('\n') print('数据的初始化') print(line) a=line.split(':',1)[0] if a!='测试地址': b=line.split(':',1)[1] if a not in self.account.keys(): self.account[a]=b else: self.account[a+i]=b i=i+1 print(self.account) else: c=line.split(':',1)[0] d=line.split(':',1)[1] self.UrlList[c]=d print(self.UrlList)
时间: 2024-02-10 22:25:06 浏览: 116
readAndwrite_XML.rar_xml_xml 读写
根据你提供的代码,可以看出你在`DataInit`类的`Initdata`方法中读取文件并初始化数据。然而,在你的代码中有一些问题导致出现了错误。
首先,在第10行和第12行的`data.split(":",1)[0]`中使用了错误的索引。应该使用索引1而不是索引0来获取冒号后面的部分。修改这两行代码如下:
```python
self.testEnv = data.split(":", 1)[1]
```
接下来,你在第20行之后继续使用了已经关闭的文件对象`f`。这会导致在之后的循环中无法读取文件。为了解决这个问题,你可以将文件内容保存到一个列表中,然后关闭文件并使用列表进行后续处理。在第20行之后添加以下代码:
```python
lines = f.readlines()
f.close()
```
然后,你可以将循环修改为使用列表`lines`进行迭代。将第23行的`for line in f.readlines():`修改为`for line in lines:`。
最后,在第39行和第41行分别打印`self.account`和`self.UrlList`之前,你可以在这两行之前添加一个判断,检查是否已经正确地读取并初始化了数据。只有当数据成功读取和初始化后,才会打印这两个变量。
以下是修改后的代码:
```python
class DataInit:
def __init__(self, fileURL, testEnv, testAccount, testUrlList) -> None:
self.fileURL = fileURL
self.testEnv = testEnv
self.account = testAccount
self.UrlList = testUrlList
def Initdata(self):
with open(self.fileURL, 'r') as f:
data = f.readline()
# 测试环境
if data.split(":", 1)[0] != '测试环境':
print("未找到测试环境,请检查datainit.txt文件")
return
else:
self.testEnv = data.split(":", 1)[1]
print(self.testEnv)
data = f.readline()
i = 0
lines = f.readlines()
f.close()
for line in lines:
line = line.strip('\n')
print('数据的初始化')
print(line)
a = line.split(':', 1)[0]
if a != '测试地址':
b = line.split(':', 1)[1]
if a not in self.account.keys():
self.account[a] = b
else:
self.account[a + i] = b
i = i + 1
print(self.account)
else:
c = line.split(':', 1)[0]
d = line.split(':', 1)[1]
self.UrlList[c] = d
print(self.UrlList)
```
希望这样的修改能够解决你遇到的问题。如果还有其他问题,请随时提问。
阅读全文