Agent skill
gene-database
Query NCBI Gene via E-utilities/Datasets API. Search by symbol/ID, retrieve gene info (RefSeqs, GO, locations, phenotypes), batch lookups, for gene annotation and functional analysis.
Install this agent skill to your Project
npx add-skill https://github.com/FreedomIntelligence/OpenClaw-Medical-Skills/tree/main/skills/gene-database
SKILL.md
Gene Database
Overview
NCBI Gene is a comprehensive database integrating gene information from diverse species. It provides nomenclature, reference sequences (RefSeqs), chromosomal maps, biological pathways, genetic variations, phenotypes, and cross-references to global genomic resources.
When to Use This Skill
This skill should be used when working with gene data including searching by gene symbol or ID, retrieving gene sequences and metadata, analyzing gene functions and pathways, or performing batch gene lookups.
Quick Start
NCBI provides two main APIs for gene data access:
- E-utilities (Traditional): Full-featured API for all Entrez databases with flexible querying
- NCBI Datasets API (Newer): Optimized for gene data retrieval with simplified workflows
Choose E-utilities for complex queries and cross-database searches. Choose Datasets API for straightforward gene data retrieval with metadata and sequences in a single request.
Common Workflows
Search Genes by Symbol or Name
To search for genes by symbol or name across organisms:
- Use the
scripts/query_gene.pyscript with E-utilities ESearch - Specify the gene symbol and organism (e.g., "BRCA1 in human")
- The script returns matching Gene IDs
Example query patterns:
- Gene symbol:
insulin[gene name] AND human[organism] - Gene with disease:
dystrophin[gene name] AND muscular dystrophy[disease] - Chromosome location:
human[organism] AND 17q21[chromosome]
Retrieve Gene Information by ID
To fetch detailed information for known Gene IDs:
- Use
scripts/fetch_gene_data.pywith the Datasets API for comprehensive data - Alternatively, use
scripts/query_gene.pywith E-utilities EFetch for specific formats - Specify desired output format (JSON, XML, or text)
The Datasets API returns:
- Gene nomenclature and aliases
- Reference sequences (RefSeqs) for transcripts and proteins
- Chromosomal location and mapping
- Gene Ontology (GO) annotations
- Associated publications
Batch Gene Lookups
For multiple genes simultaneously:
- Use
scripts/batch_gene_lookup.pyfor efficient batch processing - Provide a list of gene symbols or IDs
- Specify the organism for symbol-based queries
- The script handles rate limiting automatically (10 requests/second with API key)
This workflow is useful for:
- Validating gene lists
- Retrieving metadata for gene panels
- Cross-referencing gene identifiers
- Building gene annotation tables
Search by Biological Context
To find genes associated with specific biological functions or phenotypes:
- Use E-utilities with Gene Ontology (GO) terms or phenotype keywords
- Query by pathway names or disease associations
- Filter by organism, chromosome, or other attributes
Example searches:
- By GO term:
GO:0006915[biological process](apoptosis) - By phenotype:
diabetes[phenotype] AND mouse[organism] - By pathway:
insulin signaling pathway[pathway]
API Access Patterns
Rate Limits:
- Without API key: 3 requests/second for E-utilities, 5 requests/second for Datasets API
- With API key: 10 requests/second for both APIs
Authentication: Register for a free NCBI API key at https://www.ncbi.nlm.nih.gov/account/ to increase rate limits.
Error Handling: Both APIs return standard HTTP status codes. Common errors include:
- 400: Malformed query or invalid parameters
- 429: Rate limit exceeded
- 404: Gene ID not found
Retry failed requests with exponential backoff.
Script Usage
query_gene.py
Query NCBI Gene using E-utilities (ESearch, ESummary, EFetch).
python scripts/query_gene.py --search "BRCA1" --organism "human"
python scripts/query_gene.py --id 672 --format json
python scripts/query_gene.py --search "insulin[gene] AND diabetes[disease]"
fetch_gene_data.py
Fetch comprehensive gene data using NCBI Datasets API.
python scripts/fetch_gene_data.py --gene-id 672
python scripts/fetch_gene_data.py --symbol BRCA1 --taxon human
python scripts/fetch_gene_data.py --symbol TP53 --taxon "Homo sapiens" --output json
batch_gene_lookup.py
Process multiple gene queries efficiently.
python scripts/batch_gene_lookup.py --file gene_list.txt --organism human
python scripts/batch_gene_lookup.py --ids 672,7157,5594 --output results.json
API References
For detailed API documentation including endpoints, parameters, response formats, and examples, refer to:
references/api_reference.md- Comprehensive API documentation for E-utilities and Datasets APIreferences/common_workflows.md- Additional examples and use case patterns
Search these references when needing specific API endpoint details, parameter options, or response structure information.
Data Formats
NCBI Gene data can be retrieved in multiple formats:
- JSON: Structured data ideal for programmatic processing
- XML: Detailed hierarchical format with full metadata
- GenBank: Sequence data with annotations
- FASTA: Sequence data only
- Text: Human-readable summaries
Choose JSON for modern applications, XML for legacy systems requiring detailed metadata, and FASTA for sequence analysis workflows.
Best Practices
- Always specify organism when searching by gene symbol to avoid ambiguity
- Use Gene IDs for precise lookups when available
- Batch requests when working with multiple genes to minimize API calls
- Cache results locally to reduce redundant queries
- Include API key in scripts for higher rate limits
- Handle errors gracefully with retry logic for transient failures
- Validate gene symbols before batch processing to catch typos
Resources
This skill includes:
scripts/
query_gene.py- Query genes using E-utilities (ESearch, ESummary, EFetch)fetch_gene_data.py- Fetch gene data using NCBI Datasets APIbatch_gene_lookup.py- Handle multiple gene queries efficiently
references/
api_reference.md- Detailed API documentation for both E-utilities and Datasets APIcommon_workflows.md- Examples of common gene queries and use cases
Recommended Agent Skills
Expand your agent's capabilities with these related and highly-rated skills.
vcf-annotator
Annotate VCF variants with VEP, ClinVar, gnomAD frequencies, and ancestry-aware context. Generates prioritised variant reports.
chemist-analyst
Analyzes events through chemistry lens using molecular structure, reaction mechanisms, thermodynamics, kinetics, and analytical techniques (spectroscopy, chromatography, mass spectrometry). Provides insights on chemical processes, material properties, reaction pathways, synthesis, and analytical methods. Use when: Chemical reactions, material analysis, synthesis planning, process optimization, environmental chemistry. Evaluates: Molecular structure, reaction mechanisms, yield, selectivity, safety, environmental impact.
bio-alignment-io
Read, write, and convert multiple sequence alignment files using Biopython Bio.AlignIO. Supports Clustal, PHYLIP, Stockholm, FASTA, Nexus, and other alignment formats for phylogenetics and conservation analysis. Use when reading, writing, or converting alignment file formats.
sleep-analyzer
分析睡眠数据、识别睡眠模式、评估睡眠质量,并提供个性化睡眠改善建议。支持与其他健康数据的关联分析。
metabolomics-workbench-database
Access NIH Metabolomics Workbench via REST API (4,200+ studies). Query metabolites, RefMet nomenclature, MS/NMR data, m/z searches, study metadata, for metabolomics and biomarker discovery.
bio-hi-c-analysis-matrix-operations
Balance, normalize, and transform Hi-C contact matrices using cooler and cooltools. Apply iterative correction (ICE), compute expected values, and generate observed/expected matrices. Use when normalizing or transforming Hi-C matrices.
Didn't find tool you were looking for?