news 2026/1/14 11:05:51

元素周期表的可视化复现

作者头像

张小明

前端开发工程师

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/1/2 0:37:49

终极JSON Hero主题美化完整指南:打造专属开发环境

还在为单调的代码界面感到审美疲劳吗?想要让你的JSON数据查看体验更加个性化?今天就来分享一套完整的JSON Hero主题美化实用技巧,让你的开发环境焕然一新! 【免费下载链接】jsonhero-web 项目地址: https://gitcode.com/gh_mir…

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

终极照片整理指南:使用Phockup快速自动分类照片和视频

终极照片整理指南:使用Phockup快速自动分类照片和视频 【免费下载链接】phockup Media sorting tool to organize photos and videos from your camera in folders by year, month and day. 项目地址: https://gitcode.com/gh_mirrors/ph/phockup 还在为杂乱…

作者头像 李华
网站建设 2026/1/2 15:24:59

ESP32-P4 SD卡与无线通信共存:5个关键配置要点详解

ESP32-P4 SD卡与无线通信共存:5个关键配置要点详解 【免费下载链接】esp-idf Espressif IoT Development Framework. Official development framework for Espressif SoCs. 项目地址: https://gitcode.com/GitHub_Trending/es/esp-idf ESP32-P4作为新一代高性…

作者头像 李华
网站建设 2026/1/2 13:32:39

5个关键步骤让你在大规模Monorepo中完美掌控Git钩子

5个关键步骤让你在大规模Monorepo中完美掌控Git钩子 【免费下载链接】husky Git hooks made easy 🐶 woof! 项目地址: https://gitcode.com/gh_mirrors/hu/husky 在现代企业级软件开发中,大规模Monorepo项目已经成为主流架构选择。面对复杂的代码…

作者头像 李华
网站建设 2026/1/2 22:08:56

终极指南:用Expo轻松打造专业级照片编辑应用

终极指南:用Expo轻松打造专业级照片编辑应用 【免费下载链接】expo An open-source platform for making universal native apps with React. Expo runs on Android, iOS, and the web. 项目地址: https://gitcode.com/GitHub_Trending/ex/expo 还在为手机照…

作者头像 李华