读取和打开功能有什么区别?

时间:2018-10-22 09:30:32

标签: python python-3.x mapping readfile

运行以下代码:

if __name__ == "__main__":

    doc = sum(map(int, open('./matrix')))
    print(doc)

    with open("./matrix") as f:

        doc1 = f.read().split('\n')
        print(sum(map(int, doc1)))

        doc2 = sum(map(int, f.read()))
        print(doc2)

输出分别是:


5537376230390876637302048746832985971773659831892672

5537376230390876637302048746832985971773659831892672

0

此外,我的矩阵输入文件包含:

"37107287533902102798797998220837590246510135740250
46376937677490009712648124896970078050417018260538
74324986199524741059474233309513058123726617309629
91942213363574161572522430563301811072406154908250
23067588207539346171171980310421047513778063246676
89261670696623633820136378418383684178734361726757
28112879812849979408065481931592621691275889832738
44274228917432520321923589422876796487670272189318
47451445736001306439091167216856844588711603153276
70386486105843025439939619828917593665686757934951
62176457141856560629502157223196586755079324193331
64906352462741904929101432445813822663347944758178
92575867718337217661963751590579239728245598838407
58203565325359399008402633568948830189458628227828
80181199384826282014278194139940567587151170094390
35398664372827112653829987240784473053190104293586
86515506006295864861532075273371959191420517255829
71693888707715466499115593487603532921714970056938
54370070576826684624621495650076471787294438377604
53282654108756828443191190634694037855217779295145
36123272525000296071075082563815656710885258350721
45876576172410976447339110607218265236877223636045
17423706905851860660448207621209813287860733969412
81142660418086830619328460811191061556940512689692
51934325451728388641918047049293215058642563049483"

那么您能告诉我打开功能和读取功能之间的区别是什么吗?

当我尝试在doc2上添加拆分时,它应该像这样:

doc2 = sum(map(int, f.read().split("\n")))

但是我得到了错误:

ValueError: invalid literal for int() with base 10: ''

我知道有人问过这个问题,但是我试图理解开放阅读之间的区别。

感谢您的回答

谢谢

1 个答案:

答案 0 :(得分:0)

open()返回一个打开的文件对象,您可以从中打开read数据。一次的字节数,一次的所有数据或遍历行(与for循环一起使用时的行为)

在您的特定输出中,问题出在read的{​​{1}}上使用f

在较早的行doc2中,所有数据已被读取,并且我们已经到达EOF,因此doc1 = f.read().split('\n')的所有数据都为0。