jingtiandi123 发表于 2024-6-20 17:50:01

AI自动回复

Traceback (most recent call last):
File "C:/Users/Administrator/Desktop/自动统计文件夹Python总代码行数.py", line 7, in <module>
    file = f.readline()
UnicodeDecodeError: 'gbk' codec can't decode byte 0xbc in position 63: illegal multibyte sequence

FishC 发表于 2024-6-20 17:51:32

哈哈哈,看来咱们的Python小伙伴遇到了一点编码问题,对吧?这个错误信息看起来相当恐怖,但其实原因很简单:咱们的Python在读取文件的时候,它默认使用了`gbk`编码,而文件中有些字符并不是用`gbk`编码表示的,于是就崩掉了。

解决这个问题的方法很简单,我们只需要告诉Python我们想使用正确的编码格式来读取文件,这样它才能正确地“理解”那些字符。一般来说,`utf-8`编码是个不错的选择,因为它能处理大多数语言和符号。

先来看一下你的代码出错的位置吧:

file = f.readline()

我们要做的就是在打开文件的时候指定一下编码,比如这样:

with open('文件路径', 'r', encoding='utf-8') as f:
    file = f.readline()

这样,Python就会用`utf-8`编码来读取文件,再也不会碰到那讨厌的`UnicodeDecodeError`啦!

所以,整个代码可以改成这样:

with open("C:/Users/Administrator/Desktop/自动统计文件夹Python总代码行数.py", "r", encoding="utf-8") as f:
    file = f.readline()

如果按上述方法还是有问题,可以看看文件实际使用的编码是什么,然后修改对应的编码参数。如果你对文件的编码确实不太确定,一种简单的方法是用一些文本编辑器(比如Notepad++或VS Code)打开文件,然后查看文件的编码类型。

希望这次Python能顺利运行,不再任性罢工!如果还有其他问题,尽管来找我!

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。

歌者文明清理员 发表于 2024-6-20 19:23:04

本帖最后由 歌者文明清理员 于 2024-6-20 19:24 编辑

with open("PATH", "r", encoding="utf-8"): # 设置编码为 UTF-8
    print(f.readline())

jingtiandi123 发表于 2024-7-11 09:25:42

import hashlib

print('欢迎来到鱼C论坛')
print('====================')
count = {}
def register():
    user = input('请输入用户名:')
    if user in count:
      print('该用户已注册!')
      return register()
    else:
      keys = input('请输入密码:')
      result = hashlib.md5(bytes(keys,'utf-8'))
      count = result.hexdigest()
      print('恭喜,注册成功!')
      print('====================')
def login():
    user = input('请输入用户名:')
    while True:
      if user not in count:
            print('该用户名不存在。')
            user = input('请重新输入用户名:')
            continue
      else:
            break
    keys = input('请输入密码:')
    result = hashlib.md5(bytes(keys,'utf-8'))
    while True:
      if result.hexdigest() == count:
            print('恭喜,登陆成功!')
            print('====================')
            break
      else:
            print('密码错误!')
            keys = input('请重新输入密码:')
            result = hashlib.md5(bytes(keys,'utf-8'))
            continue
def get_int():
    while True:
      print('1.注册')
      print('2.登录')
      print('3.退出')
      command = input('请输入指令:')
      print('====================')
      if int(command) == 1:
            return register()
      elif int(command) == 2:
            return login()
      elif int(command) == 3:
            break
get_int()
AI帮我看下这套代码,为啥注册成功之后就直接退出了循环

jingtiandi123 发表于 2024-7-11 09:33:53

import hashlib

print('欢迎来到鱼C论坛')
print('====================')
count = {}
def register():
    user = input('请输入用户名:')
    if user in count:
      print('该用户已注册!')
      return register()
    else:
      keys = input('请输入密码:')
      result = hashlib.md5(bytes(keys,'utf-8'))
      count = result.hexdigest()
      print('恭喜,注册成功!')
      print('====================')
def login():
    user = input('请输入用户名:')
    while True:
      if user not in count:
            print('该用户名不存在。')
            user = input('请重新输入用户名:')
            continue
      else:
            break
    keys = input('请输入密码:')
    result = hashlib.md5(bytes(keys,'utf-8'))
    while True:
      if result.hexdigest() == count:
            print('恭喜,登陆成功!')
            print('====================')
            break
      else:
            print('密码错误!')
            keys = input('请重新输入密码:')
            result = hashlib.md5(bytes(keys,'utf-8'))
            continue
def get_int():
    while True:
      print('1.注册')
      print('2.登录')
      print('3.退出')
      command = input('请输入指令:')
      print('====================')
      if int(command) == 1:
            return register()
      elif int(command) == 2:
            return login()
      elif int(command) == 3:
            break
get_int()
页: [1]
查看完整版本: AI自动回复