我有满是df的文本
我想定义变量date,它总是在版本之后的三行。这是我的密码
with open(input_file1,'r') as f:
for i, line in enumerate(f):
if line.startswith('Version'):
version = line.strip()
date = line + 3
print(line,date)但是它不适用于date变量,我收到以下错误。有人能帮忙吗?
TypeError: Can't convert 'int' object to str implicitly发布于 2016-10-11 13:09:56
line是文件中行的字符串内容。i是正在解析的行的递增索引。因此,您希望读取行号i+3。如果使用.readlines()将所有行读入内存中,则可以轻松地读取前面的三行。
注意:--如果您的文件非常大,这是不可取的!
with open(input_file1,'r') as f:
lines = f.readlines()
for i, line in enumerate(lines):
if line.startswith('Version'):
version = line.strip()
date = lines[i + 3].strip()
print(line,date)发布于 2016-10-11 13:14:13
错误消息告诉您的是,您不能向字符串中添加数字。
首先需要将字符串转换为datetime对象,然后可以向其中添加任何您想要的内容。
看看这里的日期时间文档。
在您的情况下,您可能需要尝试这样的方法:
import datetime
Date = datetime.datetime.strptime(line, "%m/%d/%Y")其中,第二组参数通过行变量确定要输入datetime对象的日期的格式。您必须更改此位("%m/%d/%Y")以匹配您的输入。
https://stackoverflow.com/questions/39977812
复制相似问题