Python数据分析与展示:matplotlib绘图库入门-6

简介: Python数据分析与展示:matplotlib绘图库入门-6

plot()绘图函数

plt.plot(x, y, format_string, **kwargs)
x x轴 列表或数组
y y轴 列表或数组
fromat_string 格式字符串
    颜色字符
        b,蓝色
        g,绿色
        r,红色
        c,青绿色cyan
        m,洋红色magenta
        y,黄色
        k,黑色
        w,白色
        #008000 RGB颜色
        0.8 灰度值
    风格字符
        -  实线
        -- 破折线
        -. 点划线
        : 虚线
        '' 无线条
    标记字符
        . 点标记 
        , 像素标记
        o 实心圈标记
        v 倒三角标记
        ^ 上三角标记
        > 右三角标记
        < 左三角标记
        1 下花三角标记
        2 上花三角标记
        3 左花三角标记
        4 右花三角标记
        s 实心方形标记
        p 实心五角标记
        * 星型标记
        h 竖六边形标记
        H 横六边形标记
        + 十字标记
        x x标记
        D 菱形标记
        d 瘦菱形标记
        | 垂直线标记
**kwargs
    color 控制颜色 color="green"
    linestyle 线条风格 linestyle="dashed"
    marker 标记风格 marker="o"
    markerfacecolor 标记颜色  markerfacecolor="blue"
    markersize 标记尺寸 markersize=20
    ...

中文显示

matpoltlib默认不支持中文
方式一:matplotlib.rcParams全局设置(字典)
    font.family 显示字体
        SimHei 中文黑体
        Kaiti 中文楷体
        LiSu  中文隶书
        FangSong  中文仿宋
        YouYuan  中文幼圆
        STSong  华文宋体
    font.style 字体风格 正常normal 斜体 italic
    font.size 字体大小  整数字号或large x-small
方式二 单独设置参数 fontproperties

pyplot文本显示函数

plt.xlabel()  x轴文本标签
plt.ylabel()  y轴文本标签
plt.title()  图形整体标签
plt.text()   任意位置增加文本
plt.annotate()  带箭头的注解

绘图区域

1、plt.subplot(nrows, ncols, plot_number)
2、plt.subplot2grid(GridSpec, CurSpec, colspan=1, rowspan=1)
    设定网格,选中网格,确定选中行列区域数量,编号从0开始
    例如:plt.subplot2grid((3,3), (1,0), colspan=2)
3、GridSpes类
    from matplotlib.gridspec import GridSpec
    gs = GridSpec(3, 3)
    ax1 = plt.subplot(gs[0, :])

代码实例

引入模块


# -*- coding: utf-8 -*-
# @File    : matplotlib_demo.py
# @Date    : 2018-05-06
from matplotlib import rcParams
import matplotlib.pyplot as plt
import numpy as np

绘制图形并保存

def foo1():
    # 设置y轴数值
    plt.plot([3, 1, 4, 5, 2])
    # 设置y轴标签
    plt.ylabel("grade")
    # 保存,默认为png, dpi图片质量
    plt.savefig("img1", dpi=600)
    # 显示
    plt.show()

image.png


绘制x 轴和 y 轴的数据

def foo2():
    plt.plot([1, 2, 3, 4, 5], [3, 1, 4, 5, 2])
    plt.ylabel("grade")
    # 设置x轴,y轴起止点坐标
    plt.axis([1, 5, 0, 6])
    plt.savefig("img2", dpi=600)
    plt.show()

image.png

多条线条

def foo3():
    a = np.arange(10)
    plt.plot(a, a*1.5, a, a*2.5, a, a*3.5, a, a*4.5)
    plt.savefig("img3", dpi=600)
    plt.show()

image.png


使用格式字符串

def foo4():
    a = np.arange(10)
    plt.plot(a, a*1.5, 'go-',
             a, a*2.5, 'rx',
             a, a*3.5, '*',
             a, a*4.5, 'b-.'
             )
    plt.savefig("img4", dpi=600)
    plt.show()

image.png


使用关键字标记

def foo5():
    a = np.arange(10)
    plt.plot(a, a*1.5, color="green", linestyle="dashed", marker='o')
    plt.savefig("img5", dpi=600)
    plt.show()

image.png


使用中文,方式一 全局设置

def foo6():
    # 设置中文样式
    rcParams["font.family"]="SimHei"  #黑体
    rcParams["font.size"]= 20
    # 绘制曲线
    a = np.arange(0.0, 5.0, 0.02)
    plt.plot(a, np.cos(2*np.pi*a), "r--")
    plt.xlabel("x轴坐标")
    plt.ylabel("y轴坐标")
    plt.savefig("img6", dpi=600)
    plt.show()

image.png

使用中文,方式二 局部设置

def foo7():
    # 绘制曲线
    a = np.arange(0.0, 5.0, 0.02)
    plt.xlabel("x轴坐标", fontproperties="SimHei", fontsize=20)
    plt.ylabel("y轴坐标", fontproperties="SimHei", fontsize=20)
    plt.plot(a, np.cos(2*np.pi*a), "r--")
    plt.savefig("img7", dpi=600)
    plt.show()

image.png


设置文本参数

def foo8():
    a = np.arange(0.0, 5.0, 0.02)
    plt.plot(a, np.cos(2*np.pi*a), "r--")
    plt.xlabel("横轴:时间", fontproperties="SimHei", fontsize=15, color="green")
    plt.ylabel("纵轴:振幅", fontproperties="SimHei", fontsize=15, color="red")
    plt.title("正弦波实例$y=cos(2\pi x)$", fontproperties="SimHei", fontsize=25)
    plt.text(5, 1, "$\mu=100$", fontsize=15)
    # 注解
    plt.annotate("$\mu=100$", xy=(2, 1), xytext=(3, 1.3), 
            arrowprops=dict(facecolor="black", shrink=0.1, width=2))
    plt.axis([-1, 6, -2, 2])
    plt.grid(True)  # 显示网格
    plt.savefig("img8", dpi=600)
    plt.show()

image.png


绘图区域1

def foo9():
    def f(t):
        return np.exp(-t) * np.cos(2*np.pi*t)
    a = np.arange(0.0, 5.0, 0.02)
    # 设置绘图区域
    plt.subplot(2, 1, 1)
    plt.plot(a, f(a))
    # 设置绘图区域
    plt.subplot(212)
    plt.plot(a, np.cos(2*np.pi*a), "r--")
    plt.savefig("img9", dpi=600)
    plt.show()

image.png


绘图区域2

def foo10():
    # 左上区域
    plt.subplot2grid((3,3), (0,0), colspan=2)
    plt.plot([1, 2, 3, 4, 5], [2, 1, 2, 1, 2])
    # 右边区域
    plt.subplot2grid((3,3), (0,2), rowspan=3)
    plt.plot([1, 2, 3, 4, 5], [2, 1, 2, 1, 2])
    # 左中区域
    plt.subplot2grid((3,3), (1,0), colspan=2)
    plt.plot([1, 2, 3, 4, 5], [2, 1, 2, 1, 2])
    # 左下区域
    plt.subplot2grid((3,3), (2,0), colspan=2)
    plt.plot([1, 2, 3, 4, 5], [2, 1, 2, 1, 2])
    plt.savefig("img10", dpi=600)
    plt.show()

image.png


绘图区域3

from matplotlib.gridspec import GridSpec
def foo11():
    # 分割绘图区域
    gs = GridSpec(3, 3)
    # 在绘图区域绘图
    ax1 = plt.subplot(gs[0, :])
    ax1.plot([1, 2, 3, 4, 5], [2, 1, 2, 1, 2])
    ax2 = plt.subplot(gs[1, 0:-1])
    ax2.plot([1, 2, 3, 4, 5], [2, 1, 2, 1, 2])
    ax3 = plt.subplot(gs[2, 0:-1])
    ax3.plot([1, 2, 3, 4, 5], [2, 1, 2, 1, 2])
    ax4 = plt.subplot(gs[1:, 2])
    ax4.plot([1, 2, 3, 4, 5], [2, 1, 2, 1, 2])
    plt.savefig("img11", dpi=600)
    plt.show()

image.png

相关文章
|
3月前
|
数据采集 数据可视化 数据挖掘
Python数据分析实战:Pandas处理结构化数据的核心技巧
在数据驱动时代,结构化数据是分析决策的基础。Python的Pandas库凭借其高效的数据结构和丰富的功能,成为处理结构化数据的利器。本文通过真实场景和代码示例,讲解Pandas的核心操作,包括数据加载、清洗、转换、分析与性能优化,帮助你从数据中提取有价值的洞察,提升数据处理效率。
187 3
|
5月前
|
数据采集 数据可视化 搜索推荐
Python数据分析全流程指南:从数据采集到可视化呈现的实战解析
在数字化转型中,数据分析成为企业决策核心,而Python凭借其强大生态和简洁语法成为首选工具。本文通过实战案例详解数据分析全流程,涵盖数据采集、清洗、探索、建模、可视化及自动化部署,帮助读者掌握从数据到业务价值的完整技能链。
588 0
|
2月前
|
数据可视化 大数据 关系型数据库
基于python大数据技术的医疗数据分析与研究
在数字化时代,医疗数据呈爆炸式增长,涵盖患者信息、检查指标、生活方式等。大数据技术助力疾病预测、资源优化与智慧医疗发展,结合Python、MySQL与B/S架构,推动医疗系统高效实现。
|
3月前
|
数据可视化 数据挖掘 大数据
基于python大数据的水文数据分析可视化系统
本研究针对水文数据分析中的整合难、分析单一和可视化不足等问题,提出构建基于Python的水文数据分析可视化系统。通过整合多源数据,结合大数据、云计算与人工智能技术,实现水文数据的高效处理、深度挖掘与直观展示,为水资源管理、防洪减灾和生态保护提供科学决策支持,具有重要的应用价值和社会意义。
|
4月前
|
存储 数据挖掘 大数据
基于python大数据的用户行为数据分析系统
本系统基于Python大数据技术,深入研究用户行为数据分析,结合Pandas、NumPy等工具提升数据处理效率,利用B/S架构与MySQL数据库实现高效存储与访问。研究涵盖技术背景、学术与商业意义、国内外研究现状及PyCharm、Python语言等关键技术,助力企业精准营销与产品优化,具有广泛的应用前景与社会价值。
|
机器学习/深度学习 数据可视化 数据挖掘
使用Python进行数据分析的入门指南
本文将引导读者了解如何使用Python进行数据分析,从安装必要的库到执行基础的数据操作和可视化。通过本文的学习,你将能够开始自己的数据分析之旅,并掌握如何利用Python来揭示数据背后的故事。
|
机器学习/深度学习 数据可视化 数据挖掘
使用Python进行数据分析的入门指南
【10月更文挑战第42天】本文是一篇技术性文章,旨在为初学者提供一份关于如何使用Python进行数据分析的入门指南。我们将从安装必要的工具开始,然后逐步介绍如何导入数据、处理数据、进行数据可视化以及建立预测模型。本文的目标是帮助读者理解数据分析的基本步骤和方法,并通过实际的代码示例来加深理解。
235 3
|
7月前
|
机器学习/深度学习 数据采集 数据可视化
Python数据分析,别再死磕Excel了!
Python数据分析,别再死磕Excel了!
303 2
|
9月前
|
数据采集 机器学习/深度学习 数据挖掘
数据分析入门:从数据探索到洞察真相
数据分析入门:从数据探索到洞察真相
229 19
|
10月前
|
机器学习/深度学习 存储 数据可视化
这份Excel+Python飞速搞定数据分析手册,简直可以让Excel飞起来
本书介绍了如何将Python与Excel结合使用,以提升数据分析和处理效率。内容涵盖Python入门、pandas库的使用、通过Python包操作Excel文件以及使用xlwings对Excel进行编程。书中详细讲解了Anaconda、Visual Studio Code和Jupyter笔记本等开发工具,并探讨了NumPy、DataFrame和Series等数据结构的应用。此外,还介绍了多个Python包(如OpenPyXL、XlsxWriter等)用于在无需安装Excel的情况下读写Excel文件,帮助用户实现自动化任务和数据处理。

推荐镜像

更多