news 2026/6/10 12:41:05

元素周期表的可视化复现

作者头像

张小明

前端开发工程师

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/6 4:39:38

三大革新:8GB显存开启多模态AI普惠化时代

三大革新:8GB显存开启多模态AI普惠化时代 【免费下载链接】Qwen3-VL-8B-Thinking-FP8 项目地址: https://ai.gitcode.com/hf_mirrors/Qwen/Qwen3-VL-8B-Thinking-FP8 当传统多模态模型动辄需要24GB以上显存时,阿里通义千问团队推出的Qwen3-VL-8B…

作者头像 李华
网站建设 2026/5/24 16:04:32

OpenUSD与Maya插件深度集成:7大核心技术挑战与解决方案

OpenUSD与Maya插件深度集成:7大核心技术挑战与解决方案 【免费下载链接】OpenUSD Universal Scene Description 项目地址: https://gitcode.com/GitHub_Trending/ope/OpenUSD 在当今数字内容创作领域,OpenUSD作为通用场景描述格式正逐步成为行业标…

作者头像 李华
网站建设 2026/6/10 6:51:31

终极指南:HTTP Shortcuts让Android HTTP请求自动化变得简单!

终极指南:HTTP Shortcuts让Android HTTP请求自动化变得简单! 【免费下载链接】HTTP-Shortcuts Android app to create home screen shortcuts that trigger arbitrary HTTP requests 项目地址: https://gitcode.com/gh_mirrors/ht/HTTP-Shortcuts …

作者头像 李华
网站建设 2026/6/10 12:11:59

conda search查找可用版本:选择最适合的TensorFlow包

如何精准选择 TensorFlow 版本?用 conda search 构建稳定 AI 开发环境 在深度学习项目中,你是否曾遇到这样的场景:从 GitHub 下载了一个开源模型代码,满怀期待地运行,结果第一行就报错——“module tensorflow has no …

作者头像 李华
网站建设 2026/6/10 12:09:49

深度图生成技术突破:Stable Diffusion 2 Depth实战全解析

深度图生成技术突破:Stable Diffusion 2 Depth实战全解析 【免费下载链接】stable-diffusion-2-depth 项目地址: https://ai.gitcode.com/hf_mirrors/ai-gitcode/stable-diffusion-2-depth 在AI图像生成领域,深度图生成技术正以惊人的速度改变着…

作者头像 李华
网站建设 2026/6/10 2:03:02

Deep-Live-Cam模型加载失败?这几种方法帮你一键修复!

你是否正为Deep-Live-Cam项目中的模型加载失败而烦恼?别担心,这几乎是每个用户都会遇到的问题。作为实时人脸处理的核心工具,inswapper_128_fp16.onnx模型的加载确实容易出现各种状况。今天我就来帮你彻底解决这个难题! 【免费下载…

作者头像 李华