Python-openpyxl教程10 - 图表布局,填充图案以及进阶图表

Python-openpyxl教程10 - 图表布局,填充图案以及进阶图表,第1张

可以通过使用布局类实例的layout属性来设置画布中图表的布局。

图表可以放置在其容器中。 x 和 y 调整位置, w 和 h 调整大小。单位是容器的比例。图表不能放置在其容器之外,并且宽度和高度是主要限制:如果 x + w >1 , 则 x = 1 - w。

x是从左到右的水平位置

y是从顶部开始的垂直位置

h是图表相对于其容器的高度

w是盒子的宽度

除了大小和位置之外,相关属性的模式还可以设置为 factor 或 edge ,默认值是 factor 。

可以将layoutTarget设置为 outer 或 inner 。默认值为 outer 。

图例的位置可以通过设置它的位置进行控制 r , l , t , b 和 tr 分别控制右, 左, 顶部,底部。默认值为 r 。

或应用手动布局

整个数据系列和单个数据点可以通过 graphicalProperties 广泛地设置样式。把事情做好可能需要一些时间。

仪表图组合了一个饼图和一个环形图去创建一个"仪表"。第一个图表时包含四个切片的环形图,前三个切片与仪表的颜色相对应,第二个切片对应仪表的颜色。第四部分是甜甜圈的一半,不可见。

添加了包含三个切片的饼图。第一个和第三个切片是不可见的,因此第二个切片可以充当仪表上的指针。

使用数据系列中各个数据点的图形属性来完成效果。

图表工作表是一个只包含图表的特殊工作表。图表的所有数据必须在不同的工作表上。

首先,dataframe自带的柱状图,可以将每列作为一个图例

import pandas as pd

data=pd.read_excel()

data.bar()

1.最近遇到一个问题,关于图例legend如何画在图外的问题,并以适合的比例显示出来。

2.首先传统的做法如下,这种方式并不能满足我的要求,而且是显示在图内。

ax1.legend(loc='center left', bbox_to_anchor=(0.2, 1.12),ncol=3)1

loc表示图例的位置,有多种形式:

‘North’             图例标识放在图顶端

‘South’            图例标识放在图底端

‘East’               图例标识放在图右方

‘West’              图例标识放在图左方

‘NorthEast’       图例标识放在图右上方(默认)

‘NorthWest      图例标识放在图左上方

‘SouthEast’      图例标识放在图右下角

‘SouthWest’     图例标识放在图左下角12345678

有人说简单,有相同的方式,如下经测试不行,可能是本人用的python版本不行,所用的方式就是和前面一样,采用如下的方式来替换上面的legend位置。

‘NorthOutside’          图例标识放在图框外侧上方

‘SouthOutside’         图例标识放在图框外侧下方

‘EastOutside’           图例标识放在图框外侧右方

‘WestOutside’          图例标识放在图框外侧左方

‘NorthEastOutside’   图例标识放在图框外侧右上方

‘NorthWestOutside’  图例标识放在图框外侧左上方

‘SouthEastOutside’   图例标识放在图框外侧右下方

‘SouthWestOutside’  图例标识放在图框外侧左下方

(以上几个将图例标识放在框图外)

‘Best’                      图标标识放在图框内不与图冲突的最佳位置

‘BestOutside’           图标标识放在图框外使用最小空间的最佳位置1234567891011

bbox_to_anchor:表示legend的位置,前一个表示左右,后一个表示上下。当使用这个参数时。loc将不再起正常的作用,ncol=3表示图例三列显示。

3.有人说要解决这个问题可以采用对坐标轴放大或是缩小的方式,经本人测试可以行,但是,放大缩小的比率不让人满意,且很难控制到适合的位置。有兴趣可以参考链接,最终得出此方法不行。

4.那么就没有办法了吗?NO.NO,请看下面,最终完成如下。

这就是本人要的效果,不废话,具体做法如下

box = ax1.get_position()

ax1.set_position([box.x0, box.y0, box.width , box.height* 0.8])12

首先按上面的方式,如果你想将图例放上面就box.height*0.8,放右边就box.width*0.8其它方式一样。同时配合下面来使用。

ax1.legend(loc='center left', bbox_to_anchor=(0.2, 1.12),ncol=3)1

主要是bbox_to_anchor的使用,自己可以修改参数试下,good luck for you.

阅读全文

版权声明:原创文章,未经博主


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/bake/11569159.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-17
下一篇 2023-05-17

发表评论

登录后才能评论

评论列表(0条)

保存