1. 首页
  2. IT资讯

Python数据分析初体验,需要解答的三大问题!

本文约1200字,阅读需要4分钟

关键词:Python 小白 环境搭建 读取报错 中文乱码

本文针对初学Python的童鞋们的常见提问给出了解决方案

经常有初学python的小可爱,遇到一些很常见、自己又解决不掉的问题的时候,非常气馁,甚至不想继续写代码~今天,我们就针对Python初体验中提问最多的三大问题,一次给出解答,包学包会!

武装你的电脑:环境搭建

Python数据分析初体验,需要解答的三大问题!

Windows系统并没有自带Python工具,需要我们自己搭建环境。对于小白,我们推荐大家安装Anaconda,一个开源的Python发行版本,安装和使用都很方便,还自带大量工具包,简直贴心。

许多小可爱在搭建环境的时候没有按要求来,导致后面出现很多问题不得不花较多时间精力去解决,很不方便。这里强调一下两个点:

1)安装路径选择C盘!

2)如图两个advanced options都要勾选!

Python数据分析初体验,需要解答的三大问题!

此外,虽然Mac系统自带Python工具,也建议使用Mac系统的初学小白安一个Anaconda,会方便很多~

读取数据报错应对

首先将EXCEL文件另存为CSV文件,再调用pandas工具包进行读取。

importnumpyasnpimportpandasaspdimportmatplotlib.pyplotasplt#numpy:科学计算工具包#pandas:数据分析工具包#malplotlib:图表绘制工具包#improt语句:加载工具包data=pd.read_csv("路径\地市级党委书记数据库(2000-10).csv",encoding="gbk",engine='python')print(data)

对于读取数据时的报错情况,参考如下解决方案:

1)检查所有代码是不是都是英文,特别是标点!

#检查每一处逗号,单双引号,括号

2)excel转csv时,可设置编码为UTF-8,并更改参数

encoding='utf-8'

3)mac系统导出csv时,可以更改参数

encoding="gb18030"

4)可将文件名改为英文文件名,例如“data.csv”

data.csv

5)设置engine='python'

engine='python'

6)在数据量不大的时候,也可以用read_excel, 代码则是

data=pd.read_excel(‘路径.xlsx’)

前提是数据放在第一个sheet;如果是第二个sheet,代码改为

data=pd.read_excel(‘路径.xlsx’,sheet_name=1)

*读取sheet_name编号是从0开始的,1代表第二个sheet

matplotlib中文乱码

也是很常见也很头大的问题~这里以win10系统,python3.6版本为例讲解一下解决步骤:

*部分摘自原答案https://www.zhihu.com/question/25404709/answer/128171562

感谢这位知友:司毅

1)找到matplotlib 配置文件:

importmatplotlibprint(matplotlib.matplotlib_fname())
#示例输出结果如下:#D:ProgramFilesPython36Libsite-packagesmatplotlibmpl-data

2)编辑器打开此文件 matplotlibrc

删除font.family和font.sans-serif两行前的#,并在font.sans-serif后添加微软雅黑字体Microsoft YaHei

Python数据分析初体验,需要解答的三大问题!

3)下载字体:msyh.ttf (微软雅黑)放在matplotlib 字体文件夹下:

#D:ProgramFilesPython36Libsite-packagesmatplotlibmpl-datafontsttf

4)删除.matplotlib/cache里面的两个缓存字体文件

C:Users你的用户名.matplotlib

5)重启Python

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/31558017/viewspace-2219665/,如需转载,请注明出处,否则将追究法律责任。

主题测试文章,只做测试使用。发布者:布吉卡,转转请注明出处:http://www.cxybcw.com/193583.html

联系我们

13687733322

在线咨询:点击这里给我发消息

邮件:1877088071@qq.com

工作时间:周一至周五,9:30-18:30,节假日休息

QR code