Scanpy 高级可视化:从默认配色到发表级图表

Scanpy 默认画出来的图,「能看」但离「能发」还有距离。这篇文章系统梳理 Scanpy 可视化的进阶技巧,帮你做出直接能贴进论文的图表。


一、默认配色的问题

python 复制代码
import scanpy as sc
import matplotlib.pyplot as plt
​
# 默认配色
sc.pl.umap(adata, color='leiden', legend_loc='on data', save='_default.pdf')

问题:

  • 默认颜色循环对色盲不友好
  • 聚类多了之后颜色难以区分
  • 保存的是 PNG,缩放会模糊

二、用 Nature 风格配色

ini 复制代码
# Nature 风格配色方案
nature_colors = [
    '#1B9E77', '#D95F02', '#7570B3', '#E7298A',
    '#66A61E', '#E6AB02', '#A6761D', '#666666',
    '#377EB8', '#FF7F00', '#4DAF4A', '#984EA3',
]
​
# 应用到 UMAP
sc.pl.umap(adata, color='leiden',
            palette=nature_colors,
            legend_loc='on data',
            save='_nature_palette.pdf')

色盲友好配色(推荐):

ini 复制代码
# 色盲友好配色(ColorBrewer Set2)
colorblind_safe = [
    '#66C2A5', '#FC8D62', '#8DA0CB', '#E78AC3',
    '#A6D854', '#FFD92F', '#E5C494', '#B3B3B3',
]
sc.pl.umap(adata, color='leiden',
            palette=colorblind_safe,
            save='_colorblind_safe.pdf')

三、矢量图输出(论文必备)

ini 复制代码
# 正确方式:保存为 PDF/SVG
sc.settings.figdir = './figures/'
​
# PDF(推荐,矢量,任意缩放)
sc.pl.umap(adata, color='cell_type',
            save='_celltype.pdf', dpi=300)
​
# SVG(网页用)
sc.pl.umap(adata, color='cell_type',
            save='_celltype.svg', dpi=300)
​
# 高分辨率 PNG(最后备选)
sc.pl.umap(adata, color='cell_type',
            save='_celltype.png', dpi=600)

注意save 参数只接受文件名后缀,实际保存路径由 sc.settings.figdir 控制。


四、DotPlot:高效展示 Marker 基因表达

ini 复制代码
# 为每个聚类展示 Top Marker
sc.pl.dotplot(adata,
    var_names=['CD3D', 'CD79A', 'FCGR3A', 'FCER1A', 'DCN'],
    groupby='leiden',
    color_map='Reds',
    figsize=(10, 4),
    save='_marker_dotplot.pdf'
)

进阶:只展示每个聚类的 Top 5 Marker:

ini 复制代码
# 获取每个聚类的 Top 5 基因
result = adata.uns['rank_genes_groups']
top5 = {}
for cluster in result['names'].dtype.names:
    top5[cluster] = result['names'][cluster][:5].tolist()
​
# 展开为列表
genes = []
groups = []
for k, v in top5.items():
    genes.extend(v)
    groups.extend([k] * len(v))
​
# 用 matrixplot 展示
sc.pl.matrixplot(adata,
    var_names=list(set(genes)),
    groupby='leiden',
    cmap='Reds',
    figsize=(12, 6),
    save='_marker_matrixplot.pdf'
)

五、UMAP 拆分多面板(一图展示多个 Marker)

ini 复制代码
# 一图展示多个基因的 UMAP
genes_to_show = ['CD3D', 'CD79A', 'FCGR3A', 'FCER1A', 'DCN', 'COL1A1']
sc.pl.umap(adata,
            color=genes_to_show,
            ncols=3,
            vmax='p99',
            save='_multi_gene_umap.pdf')

六、自定义图例和字体(符合期刊要求)

ini 复制代码
import matplotlib.pyplot as plt
import scanpy as sc
​
# 设置全局字体
sc.settings.set_figure_params(
    dpi=300,
    facecolor='white',
    fontsize=12,
    figsize=(6, 6)
)
​
# 自定义图例
sc.pl.umap(adata, color='cell_type',
            legend_loc='right margin',  # 图例放右侧
            legend_fontsize=10,
            title='Cell Type',
            save='_custom_legend.pdf')

七、发表级图表检查清单

检查项 要求
分辨率 ≥ 300 dPI(PDF/SVG 矢量最优)
字体 Arial / Helvetica(期刊通用)
配色 色盲友好,避免红绿并用
图例 清晰可读,不遮挡数据
面板标签 A/B/C 标注,符合期刊格式
颜色条 有单位说明(如:Expression Level)

相关推荐
SilentSamsara1 小时前
高并发 API 压测与调优:locust + 火焰图 + 瓶颈定位
开发语言·python·青少年编程·docker·中间件
财经资讯数据_灵砚智能1 小时前
基于全球经济类多源新闻的NLP情感分析与数据可视化(日间)2026年6月4日
人工智能·python·ai·信息可视化·自然语言处理·ai编程·灵砚智能
用户67573181940251 小时前
两个Bot不能聊天,我让它们自己建了一条高速公路
python
如烟花的信页1 小时前
易盾滑块逆向分析
javascript·爬虫·python·js逆向
常常有2 小时前
Redis:哨兵模式 (Sentinel)
redis·python·sentinel
程序员三藏2 小时前
接口测试用例设计
自动化测试·软件测试·python·测试工具·职场和发展·测试用例·接口测试
再玩一会儿看代码2 小时前
Java抽象类和接口区别_场景理解
java·开发语言·经验分享·笔记·python
大蚂蚁2号2 小时前
Python迭代器与生成器深度剖析:从底层协议到工程实战
python
专注搞钱2 小时前
AI编程实战:我用Python+LangChain搭建了一个半导体FAB智能运维Agent
python·langchain·ai编程