Den*_*ian 5 python csv for-loop if-statement python-2.7
在我的下面的代码中,由于某种原因,即使我的输出数据与新生成的数据相同,它也会继续将输出数据写入文件...
我试图让这个只当它是不同的节省,为了重现我的问题运行该脚本至少三次,它不应该被打印again一次以上
import csv
def get_html_table(data):
s = """<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Title</title>
</head>
<body>
<table id="gradient-style">
<tbody>\n"""
for row in data:
s += ' <tr>'
for counter, cell in enumerate(row):
s += r'<td>{}</td>'.format(cell)
s += '</tr>\n'
s += """ </tbody>
</table>
</body>
</html>"""
return s
with open('testoutput.html', 'rb') as old_html:
old_html = old_html.read()
identifyer = ""
with open('random.csv') as ifile, open('testoutput.html', 'wb') as ofile:
data = []
for counter, row in enumerate(csv.reader(ifile)):
if counter != 0:
datatoapp = [row[0], row[1], row[2], row[3]]
data.append(datatoapp)
html_data = get_html_table(data)
old_html = old_html.strip()
html_data = html_data.strip()
if old_html != html_data.strip():
if html_data:
print "again"
ofile.write(html_data)
print "done"
Run Code Online (Sandbox Code Playgroud)
正如您所看到的,上面的代码将csv转换为html形式,而不包含一些数据.
data,data,data,data,data
data,data,data,data,data
data,data,data,data,data
data,data,data,data,data
data,data,data,data,data
Run Code Online (Sandbox Code Playgroud)
任何想法如何解决这个问题?
这是因为您要打开文件然后进行比较,并且因为它是相同的,所以不会在文件中保存任何内容。
比较后打开文件,例如代码的底部部分:
import csv
def get_html_table(data):
s = """<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Title</title>
</head>
<body>
<table id="gradient-style">
<tbody>\n"""
for row in data:
s += ' <tr>'
for counter, cell in enumerate(row):
s += r'<td>{}</td>'.format(cell)
s += '</tr>\n'
s += """ </tbody>
</table>
</body>
</html>"""
return s
with open('testoutput.html', 'rb') as old_html:
old_html = old_html.read()
with open('random.csv') as ifile:
data = []
for counter, row in enumerate(csv.reader(ifile)):
if counter != 0:
datatoapp = [row[0], row[1], row[2], row[3]]
data.append(datatoapp)
html_data = get_html_table(data)
if old_html != html_data:
if html_data:
with open('testoutput.html', "wb") as ofile:
ofile.write(html_data)
Run Code Online (Sandbox Code Playgroud)
希望这会有所帮助:)
- Hyflex