python柱状图代码_python+matplotlib实现礼盒柱状图实例代码

演示结果:

3b7652fe47a54dff871ffa289ac772ee.png

完整代码:

import matplotlib.pyplot as plt

import numpy as np

from matplotlib.image import BboxImage

from matplotlib._png import read_png

import matplotlib.colors

from matplotlib.cbook import get_sample_data

class RibbonBox(object):

original_image = read_png(get_sample_data("Minduka_Present_Blue_Pack.png",

asfileobj=False))

cut_location = 70

b_and_h = original_image[:, :, 2]

color = original_image[:, :, 2] - original_image[:, :, 0]

alpha = original_image[:, :, 3]

nx = original_image.shape[1]

def __init__(self, color):

rgb = matplotlib.colors.to_rgba(color)[:3]

im = np.empty(self.original_image.shape,

self.original_image.dtype)

im[:, :, :3] = self.b_and_h[:, :, np.newaxis]

im[:, :, :3] -= self.color[:, :, np.newaxis]*(1. - np.array(rgb))

im[:, :, 3] = self.alpha

self.im = im

def get_stretched_image(self, stretch_factor):

stretch_factor = max(stretch_factor, 1)

ny, nx, nch = self.im.shape

ny2 = int(ny*stretch_factor)

stretched_image = np.empty((ny2, nx, nch),

self.im.dtype)

cut = self.im[self.cut_location, :, :]

stretched_image[:, :, :] = cut

stretched_image[:self.cut_location, :, :] = \

self.im[:self.cut_location, :, :]

stretched_image[-(ny - self.cut_location):, :, :] = \

self.im[-(ny - self.cut_location):, :, :]

self._cached_im = stretched_image

return stretched_image

class RibbonBoxImage(BboxImage):

zorder = 1

def __init__(self, bbox, color,

cmap=None,

norm=None,

interpolation=None,

origin=None,

filternorm=1,

filterrad=4.0,

resample=False,

**kwargs

):

BboxImage.__init__(self, bbox,

cmap=cmap,

norm=norm,

interpolation=interpolation,

origin=origin,

filternorm=filternorm,

filterrad=filterrad,

resample=resample,

**kwargs

)

self._ribbonbox = RibbonBox(color)

self._cached_ny = None

def draw(self, renderer, *args, **kwargs):

bbox = self.get_window_extent(renderer)

stretch_factor = bbox.height / bbox.width

ny = int(stretch_factor*self._ribbonbox.nx)

if self._cached_ny != ny:

arr = self._ribbonbox.get_stretched_image(stretch_factor)

self.set_array(arr)

self._cached_ny = ny

BboxImage.draw(self, renderer, *args, **kwargs)

if 1:

from matplotlib.transforms import Bbox, TransformedBbox

from matplotlib.ticker import ScalarFormatter

# Fixing random state for reproducibility

np.random.seed(19680801)

fig, ax = plt.subplots()

years = np.arange(2004, 2009)

box_colors = [(0.8, 0.2, 0.2),

(0.2, 0.8, 0.2),

(0.2, 0.2, 0.8),

(0.7, 0.5, 0.8),

(0.3, 0.8, 0.7),

]

heights = np.random.random(years.shape) * 7000 + 3000

fmt = ScalarFormatter(useOffset=False)

ax.xaxis.set_major_formatter(fmt)

for year, h, bc in zip(years, heights, box_colors):

bbox0 = Bbox.from_extents(year - 0.4, 0., year + 0.4, h)

bbox = TransformedBbox(bbox0, ax.transData)

rb_patch = RibbonBoxImage(bbox, bc, interpolation="bicubic")

ax.add_artist(rb_patch)

ax.annotate(r"%d" % (int(h/100.)*100),

(year, h), va="bottom", ha="center")

patch_gradient = BboxImage(ax.bbox,

interpolation="bicubic",

zorder=0.1,

)

gradient = np.zeros((2, 2, 4), dtype=float)

gradient[:, :, :3] = [1, 1, 0.]

gradient[:, :, 3] = [[0.1, 0.3], [0.3, 0.5]] # alpha channel

patch_gradient.set_array(gradient)

ax.add_artist(patch_gradient)

ax.set_xlim(years[0] - 0.5, years[-1] + 0.5)

ax.set_ylim(0, 10000)

fig.savefig('ribbon_box.png')

plt.show()

总结

以上就是本文关于python+matplotlib实现礼盒柱状图实例代码的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我可以为你提供一个Python+pandas+matplotlib的数据分析与可视化例,包括源码。这个例是基于一个汽车销售数据集的分析,目的是探索不同汽车品牌的销售情况以及价格分布等信息。 首先,我们需要导入必要的库和数据集: ```python import pandas as pd import matplotlib.pyplot as plt # 读取数据集 df = pd.read_csv("car_sales.csv") ``` 接下来,我们可以先对数据集进行一些基本的探索,例如查看数据集的前几行、统计描述等: ```python # 查看前几行数据 print(df.head()) # 统计描述 print(df.describe()) ``` 然后,我们可以通过使用pandas的groupby()函数对不同品牌的销售情况进行分组统计,然后绘制柱状图进行可视化: ```python # 按品牌分组统计销售量 brand_sales = df.groupby("Brand")["Units Sold"].sum() print(brand_sales) # 绘制柱状图 brand_sales.plot(kind="bar") plt.title("Car Sales by Brand") plt.xlabel("Brand") plt.ylabel("Units Sold") plt.show() ``` 接着,我们可以通过使用pandas的cut()函数将价格范围分段,然后绘制直方图进行价格分布的可视化: ```python # 将价格范围分段 price_bins = pd.cut(df["Sale Price"], 10) print(price_bins.value_counts()) # 绘制直方图 df["Sale Price"].plot(kind="hist", bins=10) plt.title("Price Distribution") plt.xlabel("Price Range") plt.ylabel("Frequency") plt.show() ``` 最后,我们可以将以上的可视化结果组合在一起,形成一个完整的数据分析和可视化报告: ```python # 按品牌分组统计销售量 brand_sales = df.groupby("Brand")["Units Sold"].sum() # 绘制柱状图 brand_sales.plot(kind="bar") plt.title("Car Sales by Brand") plt.xlabel("Brand") plt.ylabel("Units Sold") plt.show() # 将价格范围分段 price_bins = pd.cut(df["Sale Price"], 10) # 绘制直方图 df["Sale Price"].plot(kind="hist", bins=10) plt.title("Price Distribution") plt.xlabel("Price Range") plt.ylabel("Frequency") plt.show() ``` 以上就是一个简单的Python+pandas+matplotlib数据分析与可视化例,你可以通过这个例学习如何使用这些工具进行数据分析和可视化。如果你想查看完整的源码,可以在这里找到:https://github.com/ChitGPT/Python-Data-Analysis-and-Visualization-Examples/blob/main/Car_Sales_Analysis.py
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值