圆月山庄资源网 Design By www.vgjia.com
茎叶图
from itertools import groupby nums2=[225, 232,232,245,235,245,270,225,240,240,217,195,225,185,200, 220,200,210,271,240,220,230,215,252,225,220,206,185,227,236] for k, g in groupby(sorted(nums2), key=lambda x: int(x) // 10): print (k, list(g)) # print('k', k) # print('g', list(g)) lst = map(str, [int(y) % 10 for y in list(g)]) print (k, '|', ' '.join(lst))
输出:
18 | 5 5 19 | 5 20 | 0 0 6 21 | 0 5 7 22 | 0 0 0 5 5 5 5 7 23 | 0 2 2 5 6 24 | 0 0 0 5 5 25 | 2 27 | 0 1
说明:
1./ 就表示 浮点数除法,返回浮点结果; // 表示整数除法。
2.itertools.groupby 按照分组函数的值对元素进行分组。
> from itertools import groupby > x = groupby(range(10), lambda x: x < 5 or x > 8) > for condition, numbers in x: print(condition, list(numbers)) 输出: True [0, 1, 2, 3, 4] False [5, 6, 7, 8] True [9] > [k for k, g in groupby('AAAABBBCCDAABBB')] ['A', 'B', 'C', 'D', 'A', 'B'] > [list(g) for k, g in groupby('AAAABBBCCD')] [['A', 'A', 'A', 'A'], ['B', 'B', 'B'], ['C', 'C'], ['D']]
3.map(function, iterable, ...) 根据提供的函数对指定序列做映射。第一个参数 function 以参数序列中的每一个元素调用 function 函数,返回包含每次 function 函数返回值的新列表。
4.循环加处理的例子
> [int(y) % 10 for y in [22,73,34,92,45]] [2, 3, 4, 2, 5]
复合饼图
import numpy as np import matplotlib as mpl from matplotlib import cm import matplotlib.pyplot as plt from matplotlib.patches import ConnectionPatch # 使图表元素中正常显示中文 mpl.rcParams['font.sans-serif'] = 'SimHei' # 使坐标轴刻度标签正常显示负号 mpl.rcParams['axes.unicode_minus'] = False #制画布 fig = plt.figure(figsize=(9,5.0625), facecolor='cornsilk') ax1 = fig.add_subplot(121) ax2 = fig.add_subplot(122) # 调整子区布局 fig.subplots_adjust(wspace=0) # 大饼图的制作 labels = ['成都','武汉','昆明','贵阳','西安','其它'] size = [802,530,477,256,233,307] # 分裂距离 explode=(0,0,0,0,0,0.1) ax1.pie(size, # 数据 autopct='%1.1f%%', # 锲形块的数据标签格式 startangle=30, # 锲形块开始角度 labels=labels, colors=cm.Blues(range(10, 300, 50)), explode=explode) #小饼图的制作 labels2 = ['西宁','拉萨','乌鲁木齐','兰州'] size2 = [102,79, 76, 50] width=0.2 ax2.pie(size2, autopct='%1.1f%%', startangle=90, labels=labels2, colors=cm.Blues(range(10, 300, 50)), radius=0.5, shadow=False) #使用ConnectionPatch画出两个饼图的间连线 #先得到饼图边缘的数据 theta1, theta2 = ax1.patches[-1].theta1, ax1.patches[-1].theta2 center, r = ax1.patches[-1].center, ax1.patches[-1].r #画出上边缘的连线 x = r*np.cos(np.pi/180*theta2)+center[0] y = np.sin(np.pi/180*theta2)+center[1] con1 = ConnectionPatch(xyA=(0, 0.5), xyB=(x,y), coordsA=ax2.transData, coordsB=ax1.transData, axesA=ax2,axesB=ax1) print(-width/2, 0.5) print(x,y) #画出下边缘的连线 x = r*np.cos(np.pi/180*theta1) + center[0] y = np.sin(np.pi/180*theta1) + center[1] con2 = ConnectionPatch(xyA=(-0.1, -0.49), xyB=(x,y), coordsA='data', coordsB='data', axesA=ax2,axesB=ax1) # 添加连接线 for con in [con1, con2]: con.set_color('gray') ax2.add_artist(con) con.set_linewidth(1) plt.show()
输出:
以上就是用python 绘制茎叶图和复合饼图的详细内容,更多关于python 绘制茎叶图和复合饼图的资料请关注其它相关文章!
圆月山庄资源网 Design By www.vgjia.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
圆月山庄资源网 Design By www.vgjia.com
暂无评论...
更新日志
2024年11月01日
2024年11月01日
- 群星《狐妖小红娘月红篇 电视剧原声带》[320K/MP3][233.61MB]
- 英雄联盟s14四强淘汰赛规则是什么 全球总决赛四强淘汰赛规则详解
- 英雄联盟s14四强赛怎么分组 S14全球总决赛四强赛分组规则详解
- 英雄联盟s14四强赛抽签规则是什么 S14全球总决赛四强抽签规则详解
- ButterQuartet-ScintillaEarlyItalianStringQuartets(DeLuxe)(2024)[24Bit-WAV]
- 草原最美情歌《迷醉女中音》2CD/DTS-ES[WAV]
- 爵士女伶何芸妮《靡靡之音》(香港版)[WAVCUE]
- 游戏中辱骂他人同样侵犯名誉权 一玩家被判道歉
- 老游戏远程共享申请失败 美国版权局拒绝豁免请愿
- 通过本地化支付解决方案,解锁150亿美元拉美和非洲游戏市场
- 群星《狐妖小红娘月红篇 电视剧原声带》[FLAC/分轨][574.68MB]
- 群星《红色冲浪板 电影配乐专辑》[320K/MP3][106.63MB]
- 罗艺恒《What Could've Been》[320K/MP3][50.62MB]
- 于台烟.1989-人间山水【银河唱片】【WAV+CUE】
- 杨克强.1992-特制的面具【恩华声视】【WAV+CUE】