chembl-search
Original:🇺🇸 English
Translated
2 scripts
Search ChEMBL bioactive molecules database with natural language queries. Find compounds and assay data with Valyu semantic search.
37installs
Added on
NPX Install
npx skill4agent add yorkeccak/scientific-skills chembl-searchTags
Translated version includes tags in frontmatterSKILL.md Content
View Translation Comparison →ChEMBL Search
Search the complete ChEMBL database of bioactive molecules, drug targets, and binding data using natural language queries powered by Valyu's semantic search API.
Why This Skill is Powerful
- No API Parameter Parsing: Just pass natural language queries directly - no need to construct complex search parameters
- Semantic Search: Understands the meaning of your query, not just keyword matching
- Full-Text Access: Returns complete compound and target information
- Image Links: Includes molecular structures and data visualizations
- Comprehensive Coverage: Access to all ChEMBL bioactive molecule data for drug discovery
Requirements
- Node.js 18+ (uses built-in fetch)
- Valyu API key from https://platform.valyu.ai ($10 free credits)
CRITICAL: Script Path Resolution
The commands in this documentation are relative to this skill's installation directory.
scripts/searchBefore running any command, locate the script using:
bash
CHEMBL_SCRIPT=$(find ~/.claude/plugins/cache -name "search" -path "*/chembl-search/*/scripts/*" -type f 2>/dev/null | head -1)Then use the full path for all commands:
bash
$CHEMBL_SCRIPT "kinase inhibitors" 15API Key Setup Flow
When you run a search and receive , follow this flow:
"setup_required": true-
Ask the user for their API key: "To search ChEMBL, I need your Valyu API key. Get one free ($10 credits) at https://platform.valyu.ai"
-
Once the user provides the key, run:bash
scripts/search setup <api-key> -
Retry the original search.
When to Use This Skill
- Finding bioactive compounds for drug discovery
- Target-based compound searching
- Compound property optimization
- Assay data and biological activity research
- Structure-activity relationship studies
- Lead compound identification
Output Format
json
{
"success": true,
"type": "chembl_search",
"query": "kinase inhibitors",
"result_count": 10,
"results": [
{
"title": "Compound/Assay Title",
"url": "https://chembl.org/...",
"content": "Compound data, targets, assay results...",
"source": "chembl",
"relevance_score": 0.95,
"images": ["https://example.com/structure.png"]
}
],
"cost": 0.025
}Processing Results
With jq
bash
# Get compound titles
scripts/search "query" 10 | jq -r '.results[].title'
# Get URLs
scripts/search "query" 10 | jq -r '.results[].url'
# Extract full content
scripts/search "query" 10 | jq -r '.results[].content'Common Use Cases
Drug Discovery
bash
# Find lead compounds
scripts/search "JAK2 selective inhibitors for myelofibrosis" 50Target Validation
bash
# Search for target information
scripts/search "protein kinase B binding assays" 20SAR Analysis
bash
# Find structure-activity relationships
scripts/search "benzimidazole derivatives anticancer activity" 15Mechanism Research
bash
# Search for mechanism data
scripts/search "allosteric modulators of NMDA receptors" 25Error Handling
All commands return JSON with field:
successjson
{
"success": false,
"error": "Error message"
}Exit codes:
- - Success
0 - - Error (check JSON for details)
1
API Endpoint
- Base URL:
https://api.valyu.ai/v1 - Endpoint:
/search - Authentication: X-API-Key header
Architecture
scripts/
├── search # Bash wrapper
└── search.mjs # Node.js CLIDirect API calls using Node.js built-in , zero external dependencies.
fetch()Adding to Your Project
If you're building an AI project and want to integrate ChEMBL Search directly into your application, use the Valyu SDK:
Python Integration
python
from valyu import Valyu
client = Valyu(api_key="your-api-key")
response = client.search(
query="your search query here",
included_sources=["valyu/valyu-chembl"],
max_results=20
)
for result in response["results"]:
print(f"Title: {result['title']}")
print(f"URL: {result['url']}")
print(f"Content: {result['content'][:500]}...")TypeScript Integration
typescript
import { Valyu } from "valyu-js";
const client = new Valyu("your-api-key");
const response = await client.search({
query: "your search query here",
includedSources: ["valyu/valyu-chembl"],
maxResults: 20
});
response.results.forEach((result) => {
console.log(`Title: ${result.title}`);
console.log(`URL: ${result.url}`);
console.log(`Content: ${result.content.substring(0, 500)}...`);
});See the Valyu docs for full integration examples and SDK reference.