即使输出与原始输出相同,代码也会保存文档?

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形式,而不包含一些数据.

random.csv

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)

任何想法如何解决这个问题?

Ryf*_*lex 1

这是因为您要打开文件然后进行比较,并且因为它是相同的,所以不会在文件中保存任何内容。

比较后打开文件,例如代码的底部部分:

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