关于文件中"wb"与"rb"的理解


“rb”,”wb”这两种方式在操作文件时,直接跳过了系统的编码方式,在windows系统中,用的编码为gbk:

with open(“a.txt”,”w”) as f1:

         F1.write(“aa”)

     默认用gbk进行编码并且写入。

②: with open(“a.txt”,”r”) as f1:

       Print(F1.read())

默认用gbk编码进行解码

③: with open(“a.txt”,”wb”) as f1:

        F1.write(“aa”.encode(“utf-8”))

跳过了系统的gbk而用的是utf-8进行编码,这跟”w”不一样,好像”w”只不过省略了一个步骤即:”aa”.encode(“gbk”),”wb”只不过对作者要求的更多即:完成了计算机自动完成的步骤。

with open(“a.txt”,”rb”) as f1:

     Print(f1.read().decode(“utf-8”))

    

程序员自己手动指定了二进制的解码方式为utf-8而不是gbk

⑤: with open(“a.txt”,”r”,encoding = “utf-8”) as f1:

Print(f1.read())

此时指定了”r”的编码方式为utf-8,跟”rb” 有一样的效果

 

总结:1”wb”,”rb”能够跳过系统自带的编码方式

      2、是不是,如果是”rb”,那么在print(f1.read())之前已经将二进制转换为了字符串,所以才会有with open(a.txt,r,encoding = utf-8) as f1 中的encoding.


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM