news 2026/6/21 1:04:27

元素周期表的可视化复现

作者头像

张小明

前端开发工程师

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/6/18 0:36:30

conda env remove删除环境:清理废弃的TensorFlow测试空间

conda env remove删除环境:清理废弃的TensorFlow测试空间 在现代AI开发中,一个看似简单的操作——删掉一个用完的虚拟环境,往往被忽视。但正是这些“临时”创建的测试空间,在项目迭代频繁的背景下,逐渐堆积成技术债&am…

作者头像 李华
网站建设 2026/6/14 17:45:23

conda update conda最佳实践:维护TensorFlow基础环境

conda update conda最佳实践:维护TensorFlow基础环境 在深度学习项目开发中,最令人头疼的往往不是模型调参,而是环境配置——“在我机器上明明能跑”的问题反复上演。一个看似简单的 ImportError 或 GPU 无法识别,可能让新手耗费数…

作者头像 李华
网站建设 2026/6/15 0:05:53

Komikku终极指南:免费开源漫画阅读器的完整使用教程

Komikku终极指南:免费开源漫画阅读器的完整使用教程 【免费下载链接】komikku Free and open source manga reader for Android 项目地址: https://gitcode.com/gh_mirrors/ko/komikku 还在为找不到合适的漫画阅读应用而烦恼吗?Komikku作为一款完…

作者头像 李华
网站建设 2026/6/18 0:32:05

微码解析利器MCExtractor:全方位处理器微码分析指南

微码解析利器MCExtractor:全方位处理器微码分析指南 【免费下载链接】MCExtractor Intel, AMD, VIA & Freescale Microcode Extraction Tool 项目地址: https://gitcode.com/gh_mirrors/mc/MCExtractor 微码是现代处理器中至关重要的底层指令集&#xff…

作者头像 李华
网站建设 2026/6/18 20:30:46

Nextcloud Docker镜像三大版本全方位解析:从入门到精通

Nextcloud Docker镜像三大版本全方位解析:从入门到精通 【免费下载链接】docker ⛴ Docker image of Nextcloud 项目地址: https://gitcode.com/gh_mirrors/dock/docker 在当今数据主权日益重要的时代,Nextcloud作为领先的开源自托管云存储解决方…

作者头像 李华