由于在Python2 中的默认编码为ASCII,但是在Python3中的默认编码为UTF-8。
问题:
所以在使用np.load(det.npy)的时候会出现错误提示:
you may need to pass the encoding= option to numpy.load
解决方法:
当遇到这种情况的时候,用np.load(det.npy,encoding="latin1")就可以了。
补充:python解决numpy导入乱码问题------已解决
使用numpy的loadtxt时,发现报错。
经历如下:
// Visual Studio Code var foo = 'bar'; import numpy as np if __name__ == "__main__": dataset = np.loadtxt("C:/Users/yanruyu/Documents/code/python/GA/dataset.txt") print(dataset)
打印出的结果:
ValueError: could not convert string to float: '1,1锛�'
解决经历:
第一次:
// Visual Studio Code var foo = 'bar'; import numpy as np if __name__ == "__main__": dataset = np.loadtxt("C:/Users/yanruyu/Documents/code/python/GA/dataset.txt",dtype="str") #默认为float,需要dtype print(dataset)
打印出的结果:
['1,1锛�' '1,2锛�' '1.5,1.5锛�' '3,4锛�' '4,4锛�']
第二次:
// Visual Studio Code var foo = 'bar'; import numpy as np if __name__ == "__main__": dataset = np.loadtxt("C:/Users/yanruyu/Documents/code/python/GA/dataset.txt",dtype="str",encoding='utf-8') #默认为float,需要dtype print(dataset)
打印出的结果:
['1,1,A' '1,2,A' '1.5,1.5,A' '3,4,B' '4,4,B']
优化后
// Visual Studio Code var foo = 'bar'; import numpy as np if __name__ == "__main__": dataset = np.loadtxt("C:/Users/yanruyu/Documents/code/python/GA/dataset.txt",dtype="str",encoding='utf-8',delimiter=',') #默认为float,需要dtype # x=dataset[:,:-1] print(dataset)
打印的结果:
PS C:\Users\yanruyu> & D:/Anaconda3/python.exe c:/Users/yanruyu/Documents/code/python/GA/text.py
[['1' '1,A'] ['1' '2,A'] ['1.5' '1.5,A'] ['3' '4,B'] ['4' '4,B']]
以上为个人经验,希望能给大家一个参考,也希望大家多多支持华域联盟。如有错误或未考虑完全的地方,望不吝赐教。
您可能感兴趣的文章:
- 详解python中文编码问题
- python基础之编码规范总结
- Python3 json模块之编码解码方法讲解
- python 编码中为什么要写类型注解?
- python源文件的字符编码知识点详解
- Python新建项目自动添加介绍和utf-8编码的方法
- python中字符串的编码与解码详析
- Python之进行URL编码案例讲解
本文由 华域联盟 原创撰写:华域联盟 » 解决python3 中的np.load编码问题
转载请保留出处和原文链接:https://www.cnhackhy.com/20363.htm