news 2026/4/3 5:25:50

元素周期表的可视化复现

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
元素周期表的可视化复现

元素周期表的可视化复现

frombokeh.plottingimportfigurefrombokeh.sampledata.periodic_tableimportelementsfrombokeh.transformimportdodge,factor_cmapfrombokeh.ioimportoutput_notebook,show# 在notebook中展示output_notebook()

数据探索

以下数据如果有需要的同学可关注公众号HsuHeinrich,回复【数据可视化】自动获取~

# 导入数据frombokeh.sampledata.periodic_tableimportelements df=elements.copy()df.head()

# 数据预处理# 基本变量periods=["I","II","III","IV","V","VI","VII"]groups=[str(x)forxinrange(1,19)]cmap={"alkali metal":"#a6cee3","alkaline earth metal":"#1f78b4","metal":"#d93b43","halogen":"#999d9a","metalloid":"#e08d49","noble gas":"#eaeaea","nonmetal":"#f1d4Af","transition metal":"#599d7A",}TOOLTIPS=[("Name","@name"),("Atomic number","@{atomic number}"),("Atomic mass","@{atomic mass}"),("Type","@metal"),("CPK color","$color[hex, swatch]:CPK"),("Electronic configuration","@{electronic configuration}"),]df["atomic mass"]=df["atomic mass"].astype(str)df["group"]=df["group"].astype(str)df["period"]=[periods[x-1]forxindf.period]df=df[df.group!="-"]df=df[df.symbol!="Lr"]df=df[df.symbol!="Lu"]

绘制基本的方块图

# 初始化布局p=figure(title="Periodic Table (omitting LA and AC Series)",width=1000,height=450,x_range=groups,y_range=list(reversed(periods)),tools="hover",toolbar_location=None,tooltips=TOOLTIPS)# 添加方格快r=p.rect("group","period",0.95,0.95,source=df,fill_alpha=0.6,legend_field="metal",color=factor_cmap('metal',palette=list(cmap.values()),factors=list(cmap.keys())))show(p)

# 方格上添加文字# 自定义文字属性text_props=dict(source=df,text_align="left",text_baseline="middle")x=dodge("group",-0.4,range=p.x_range)# 调整"group"所在的坐标,使其向左偏移0.4单位# 添加文字p.text(x=x,y="period",text="symbol",text_font_style="bold",**text_props)# 添加symbolp.text(x=x,y=dodge("period",0.3,range=p.y_range),text="atomic number",# 添加atomic numbertext_font_size="11px",**text_props)p.text(x=x,y=dodge("period",-0.35,range=p.y_range),text="name",# 添加nametext_font_size="7px",**text_props)p.text(x=x,y=dodge("period",-0.2,range=p.y_range),text="atomic mass",# 添加atomic masstext_font_size="7px",**text_props)p.text(x=["3","3"],y=["VI","VII"],text=["LA","AC"],text_align="center",text_baseline="middle")# 添加指定文字show(p)

# 调整下布局p.outline_line_color=Nonep.grid.grid_line_color=Nonep.axis.axis_line_color=Nonep.axis.major_tick_line_color=Nonep.axis.major_label_standoff=0p.legend.orientation="horizontal"p.legend.location="top_center"p.hover.renderers=[r]# 指标悬停只在r(之前绘制的矩形方格)上生效show(p)

参考:A rendering of the Periodic table

共勉~

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/30 1:06:52

如何快速配置Syntastic:Vim语法检查终极指南

如何快速配置Syntastic:Vim语法检查终极指南 【免费下载链接】syntastic 项目地址: https://gitcode.com/gh_mirrors/syn/syntastic 还在为Vim中找不到代码错误而烦恼吗?Syntastic就是你的救星!这个强大的Vim插件能够在编辑代码时实时…

作者头像 李华
网站建设 2026/3/27 1:48:18

Docker exec进入容器:调试正在运行的TensorFlow进程

Docker exec进入容器:调试正在运行的TensorFlow进程 在深度学习项目开发中,模型训练往往是一个长时间运行的过程。当你的 TensorFlow 任务已经在容器里跑了几个小时,突然发现日志停滞、GPU 利用率归零,或者怀疑是某个超参数设置不…

作者头像 李华
网站建设 2026/4/3 5:24:33

Stegsolve:解锁图像中隐藏的秘密世界

Stegsolve:解锁图像中隐藏的秘密世界 【免费下载链接】Stegsolve.jar下载与使用指南 Stegsolve.jar 下载与使用指南 项目地址: https://gitcode.com/open-source-toolkit/3afaf 你是否曾好奇,一张普通的图片背后可能隐藏着不为人知的信息&#xf…

作者头像 李华
网站建设 2026/4/1 10:36:52

Dense_Haze浓雾数据集:解锁55对高质量图像的去雾研究新篇章

Dense_Haze浓雾数据集:解锁55对高质量图像的去雾研究新篇章 【免费下载链接】Dense_Haze数据集 本仓库提供了 Dense_Haze 浓雾数据集,专为 CVPR 2019 NTIRE19 挑战赛设计,用以推动浓雾图像去雾技术的研究与发展。该数据集包含了精心挑选并标注…

作者头像 李华
网站建设 2026/3/31 7:25:56

Invoke-AtomicRedTeam 终极指南:从零开始掌握红队测试技术

Invoke-AtomicRedTeam 终极指南:从零开始掌握红队测试技术 【免费下载链接】invoke-atomicredteam Invoke-AtomicRedTeam is a PowerShell module to execute tests as defined in the [atomics folder](https://github.com/redcanaryco/atomic-red-team/tree/maste…

作者头像 李华