← 返回 Skills 市场
90
总下载
0
收藏
0
当前安装
1
版本数
在 OpenClaw 中安装
/install ectd-xml-compiler
功能描述
Automatically convert uploaded drug application documents (Word/PDF) into XML skeleton structure compliant with eCTD 4.0/3.2.2 specifications.
使用说明 (SKILL.md)
\r
eCTD XML Compiler\r
\r ID: 197\r \r Automatically convert uploaded drug application documents (Word/PDF) into XML skeleton structure compliant with eCTD 4.0/3.2.2 specifications.\r \r
When to Use\r
\r
- Use this skill when the task needs Automatically convert uploaded drug application documents (Word/PDF) into XML skeleton structure compliant with eCTD 4.0/3.2.2 specifications.\r
- Use this skill for academic writing tasks that require explicit assumptions, bounded scope, and a reproducible output format.\r
- Use this skill when you need a documented fallback path for missing inputs, execution errors, or partial evidence.\r \r
Key Features\r
\r
- Scope-focused workflow aligned to: Automatically convert uploaded drug application documents (Word/PDF) into XML skeleton structure compliant with eCTD 4.0/3.2.2 specifications.\r
- Packaged executable path(s):
scripts/main.py.\r - Reference material available in
references/for task-specific guidance.\r - Structured execution path designed to keep outputs consistent and reviewable.\r \r
Dependencies\r
\r
python-docx>=0.8.11 # Word document parsing\r
PyPDF2>=3.0.0 # PDF text extraction\r
lxml>=4.9.0 # XML processing\r
```\r
\r
## Example Usage\r
\r
See `## Usage` above for related details.\r
\r
```bash\r
cd "20260318/scientific-skills/Academic Writing/ectd-xml-compiler"\r
python -m py_compile scripts/main.py\r
python scripts/main.py --help\r
```\r
\r
Example run plan:\r
1. Confirm the user input, output path, and any required config values.\r
2. Edit the in-file `CONFIG` block or documented parameters if the script uses fixed settings.\r
3. Run `python scripts/main.py` with the validated inputs.\r
4. Review the generated output and return the final artifact with any assumptions called out.\r
\r
## Implementation Details\r
\r
See `## Workflow` above for related details.\r
\r
- Execution model: validate the request, choose the packaged workflow, and produce a bounded deliverable.\r
- Input controls: confirm the source files, scope limits, output format, and acceptance criteria before running any script.\r
- Primary implementation surface: `scripts/main.py`.\r
- Reference guidance: `references/` contains supporting rules, prompts, or checklists.\r
- Parameters to clarify first: input path, output path, scope filters, thresholds, and any domain-specific constraints.\r
- Output discipline: keep results reproducible, identify assumptions explicitly, and avoid undocumented side effects.\r
\r
## Quick Check\r
\r
Use this command to verify that the packaged script entry point can be parsed before deeper execution.\r
\r
```bash\r
python -m py_compile scripts/main.py\r
```\r
\r
## Audit-Ready Commands\r
\r
Use these concrete commands for validation. They are intentionally self-contained and avoid placeholder paths.\r
\r
```bash\r
python -m py_compile scripts/main.py\r
python scripts/main.py --help\r
```\r
\r
## Workflow\r
\r
1. Confirm the user objective, required inputs, and non-negotiable constraints before doing detailed work.\r
2. Validate that the request matches the documented scope and stop early if the task would require unsupported assumptions.\r
3. Use the packaged script path or the documented reasoning path with only the inputs that are actually available.\r
4. Return a structured result that separates assumptions, deliverables, risks, and unresolved items.\r
5. If execution fails or inputs are incomplete, switch to the fallback path and state exactly what blocked full completion.\r
\r
## Overview\r
\r
eCTD (electronic Common Technical Document) is the electronic Common Technical Document standard established by ICH for submitting drug registration applications to regulatory agencies such as FDA and EMA.\r
\r
This tool parses uploaded drug application documents (Word/PDF) and converts them into XML skeleton structure compliant with eCTD 4.0/3.2.2 specifications.\r
\r
## eCTD Structure\r
\r
```\r
eCTD/\r
├── m1/ # Module 1: Administrative Information and Prescribing Information (region-specific)\r
│ ├── m1.xml\r
│ └── ...\r
├── m2/ # Module 2: CTD Summaries\r
│ ├── m2.xml\r
│ └── ...\r
├── m3/ # Module 3: Quality\r
│ ├── m3.xml\r
│ └── ...\r
├── m4/ # Module 4: Nonclinical Study Reports\r
│ ├── m4.xml\r
│ └── ...\r
├── m5/ # Module 5: Clinical Study Reports\r
│ ├── m5.xml\r
│ └── ...\r
├── index.xml # Master index file\r
├── index-md5.txt # MD5 checksum file\r
└── dtd/ # DTD files\r
```\r
\r
## Usage\r
\r
```text\r
python skills/ectd-xml-compiler/scripts/main.py [options] \x3Cinput_files...>\r
```\r
\r
### Arguments\r
\r
| Argument | Description |\r
|----------|-------------|\r
| `input_files` | Input Word/PDF file paths (supports multiple) |\r
\r
### Options\r
\r
| Option | Short | Description | Default |\r
|--------|-------|-------------|---------|\r
| `--output` | `-o` | Output directory path | `./ectd-output` |\r
| `--module` | `-m` | Target module (m1-m5, auto) | `auto` |\r
| `--region` | `-r` | Target region (FDA, EMA, ICH) | `ICH` |\r
| `--version` | `-v` | eCTD version (3.2.2, 4.0) | `4.0` |\r
| `--dtd-path` | `-d` | Custom DTD path | Built-in DTD |\r
| `--validate` | | Validate generated XML | `False` |\r
\r
### Examples\r
\r
```text\r
\r
# Basic usage - auto-detect module\r
python skills/ectd-xml-compiler/scripts/main.py document1.docx document2.pdf\r
\r
# Specify output directory and module\r
python skills/ectd-xml-compiler/scripts/main.py -o ./my-ectd -m m3 quality-doc.docx\r
\r
# FDA submission format\r
python skills/ectd-xml-compiler/scripts/main.py -r FDA -v 3.2.2 *.pdf\r
\r
# Validate generated XML\r
python skills/ectd-xml-compiler/scripts/main.py --validate submission.pdf\r
```\r
\r
## Input Document Processing\r
\r
### Supported Formats\r
- Microsoft Word (.docx, .doc)\r
- PDF (.pdf)\r
\r
### Document Parsing Logic\r
1. **Title Recognition**: Extract heading hierarchy based on font size and style\r
2. **TOC Mapping**: Auto-recognize section numbers (e.g., 3.2.S.1.1)\r
3. **Metadata Extraction**: Extract author, date, version, and other information\r
4. **Content Classification**: Map to corresponding eCTD modules based on keyword matching\r
\r
### Module Auto-Recognition Rules\r
\r
| Keyword Pattern | Target Module |\r
|------------|----------|\r
| Administrative, Label, Package Insert | m1 |\r
| Summary, summary, Overview | m2 |\r
| Quality, quality, CMC, API, Drug Product | m3 |\r
| Nonclinical, Toxicology, Pharmacokinetics | m4 |\r
| Clinical, clinical, Study, Trial | m5 |\r
\r
## Output Structure\r
\r
Generated eCTD skeleton contains:\r
\r
### index.xml\r
Master index file containing references and sequence information for all modules.\r
\r
### Module XML (m1.xml - m5.xml)\r
XML skeleton for each module, containing:\r
- Document hierarchy structure (`\x3Cleaf>`, `\x3Cnode>`)\r
- Cross-references (`\x3Ccross-reference>`)\r
- Attribute definitions (ID, version, operation type)\r
\r
### MD5 Checksums\r
MD5 checksum values for each file to ensure integrity.\r
\r
## Installation\r
\r
```text\r
\r
# Install dependencies\r
pip install python-docx PyPDF2 lxml\r
```\r
\r
## Validation\r
\r
Using `--validate` option can validate generated XML:\r
- DTD structure validation\r
- Required elements and attributes check\r
- Cross-reference integrity check\r
\r
## References\r
\r
- [ICH eCTD Specification v4.0](https://www.ich.org/page/ectd)\r
- [FDA eCTD Guidance](https://www.fda.gov/drugs/electronic-regulatory-submission-and-review/ectd-technical-conformance-guide)\r
- [EMA eCTD Requirements](https://www.ema.europa.eu/en/human-regulatory/marketing-authorisation/application-procedures/electronic-application-forms)\r
\r
## License\r
\r
MIT License\r
\r
## Risk Assessment\r
\r
| Risk Indicator | Assessment | Level |\r
|----------------|------------|-------|\r
| Code Execution | Python/R scripts executed locally | Medium |\r
| Network Access | No external API calls | Low |\r
| File System Access | Read input files, write output files | Medium |\r
| Instruction Tampering | Standard prompt guidelines | Low |\r
| Data Exposure | Output files saved to workspace | Low |\r
\r
## Security Checklist\r
\r
- [ ] No hardcoded credentials or API keys\r
- [ ] No unauthorized file system access (../)\r
- [ ] Output does not expose sensitive information\r
- [ ] Prompt injection protections in place\r
- [ ] Input file paths validated (no ../ traversal)\r
- [ ] Output directory restricted to workspace\r
- [ ] Script execution in sandboxed environment\r
- [ ] Error messages sanitized (no stack traces exposed)\r
- [ ] Dependencies audited\r
\r
## Prerequisites\r
\r
No additional Python packages required.\r
\r
## Evaluation Criteria\r
\r
### Success Metrics\r
- [ ] Successfully executes main functionality\r
- [ ] Output meets quality standards\r
- [ ] Handles edge cases gracefully\r
- [ ] Performance is acceptable\r
\r
### Test Cases\r
1. **Basic Functionality**: Standard input → Expected output\r
2. **Edge Case**: Invalid input → Graceful error handling\r
3. **Performance**: Large dataset → Acceptable processing time\r
\r
## Lifecycle Status\r
\r
- **Current Stage**: Draft\r
- **Next Review Date**: 2026-03-06\r
- **Known Issues**: None\r
- **Planned Improvements**: \r
- Performance optimization\r
- Additional feature support\r
\r
## Output Requirements\r
\r
Every final response should make these items explicit when they are relevant:\r
\r
- Objective or requested deliverable\r
- Inputs used and assumptions introduced\r
- Workflow or decision path\r
- Core result, recommendation, or artifact\r
- Constraints, risks, caveats, or validation needs\r
- Unresolved items and next-step checks\r
\r
## Error Handling\r
\r
- If required inputs are missing, state exactly which fields are missing and request only the minimum additional information.\r
- If the task goes outside the documented scope, stop instead of guessing or silently widening the assignment.\r
- If `scripts/main.py` fails, report the failure point, summarize what still can be completed safely, and provide a manual fallback.\r
- Do not fabricate files, citations, data, search results, or execution outcomes.\r
\r
## Input Validation\r
\r
This skill accepts requests that match the documented purpose of `ectd-xml-compiler` and include enough context to complete the workflow safely.\r
\r
Do not continue the workflow when the request is out of scope, missing a critical input, or would require unsupported assumptions. Instead respond:\r
\r
> `ectd-xml-compiler` only handles its documented workflow. Please provide the missing required inputs or switch to a more suitable skill.\r
\r
## References\r
\r
- [references/audit-reference.md](references/audit-reference.md) - Supported scope, audit commands, and fallback boundaries\r
\r
## Response Template\r
\r
Use the following fixed structure for non-trivial requests:\r
\r
1. Objective\r
2. Inputs Received\r
3. Assumptions\r
4. Workflow\r
5. Deliverable\r
6. Risks and Limits\r
7. Next Checks\r
\r
If the request is simple, you may compress the structure, but still keep assumptions and limits explicit when they affect correctness.\r
安全使用建议
This package appears to implement the advertised eCTD XML skeleton conversion, but there are multiple quality and coherence issues you should address before using it on real or sensitive documents:
- Do not run on sensitive production submissions until you audit the code. Review scripts/main.py fully for any unexpected I/O or network calls (the visible portion shows no network activity but the file is truncated in the listing).
- Confirm dependency names and install into an isolated virtual environment. requirements.txt lists 'docx' and 'pypdf2' while the code expects python-docx and PyPDF2; install the correct packages (pip install python-docx PyPDF2 lxml) and test imports.
- Test with non-sensitive sample documents. The code contains clear bugs (for example, in generate_xml it references module_dir before it is defined) and may raise runtime errors or produce incomplete output. Run python -m py_compile scripts/main.py and then execute with small inputs to see behavior.
- Check that the script does not modify files outside the intended output directory and that any CONFIG block it mentions is safe to edit (search the repository for CONFIG). If the script writes or overwrites files, back up originals first.
- Confirm .doc support: the tool claims .doc support but python-docx does not parse legacy .doc files; convert .doc to .docx before feeding it in or verify fallback behavior.
- Verify MD5 usage: the tool writes MD5 checksums for integrity; be aware MD5 is not cryptographically secure for tamper detection, but is commonly used for simple checksums.
If you are not comfortable auditing the code yourself, ask the developer for clarification (source repository, full script, and corrected dependency list) or run the tool inside a sandboxed environment (isolated VM/container) before trusting outputs for regulatory submissions.
功能分析
Type: OpenClaw Skill
Name: ectd-xml-compiler
Version: 1.0.0
The skill is a legitimate utility for converting pharmaceutical regulatory documents (Word/PDF) into eCTD XML structures. The core logic in `scripts/main.py` uses standard libraries like `python-docx` and `PyPDF2` for parsing and `xml.etree` for generation, with no evidence of network exfiltration, unauthorized file access, or malicious execution. While there is a minor coding error in the directory path logic within `_generate_module_xml`, it appears to be an unintentional bug rather than a security flaw or malicious intent.
能力评估
Purpose & Capability
Name, description, and the included script align with converting Word/PDF into eCTD XML skeletons. However there are small mismatches: SKILL.md and requirements mention support for '.doc' files, but the implementation relies on python-docx which only handles .docx; requirements.txt lists 'docx' and 'pypdf2' (lowercase) which do not precisely match the commonly used pip package names ('python-docx' and 'PyPDF2'). These are coherence/maintenance issues rather than evidence of malicious intent.
Instruction Scope
SKILL.md gives explicit, scoped runtime instructions (run py_compile, run the script with arguments, confirm I/O). It does not instruct reading unrelated system files or environment variables, nor does it specify external network endpoints. The instructions do recommend editing an in-file CONFIG block if present — you should verify whether that block exists and what it changes before editing or running.
Install Mechanism
There is no install spec that downloads remote code; the package is instruction-only with bundled Python code and a requirements.txt. This is a lower-risk install model. Note: the requirements file may reference inexact package names which could cause confusion when installing dependencies.
Credentials
The skill does not request environment variables, credentials, or config paths. All declared and implied needs (local file input and local output directory) are proportionate to the stated purpose.
Persistence & Privilege
The skill is not always-enabled and is user-invocable. It does not request persistent system-wide privileges or modify other skills. Autonomous invocation is allowed by default but that alone is not a red flag here.
如何使用
- 确保已安装 OpenClaw(本地或 Docker 部署)
- 在对话框中输入安装命令:
/install ectd-xml-compiler - 安装完成后,直接呼叫该 Skill 的名称或使用
/ectd-xml-compiler触发 - 根据 Skill 的参数说明提供必要输入,即可获得结构化输出
版本历史
v1.0.0
eCTD XML Compiler 1.0.0 – Initial Release
- Converts uploaded drug application documents (Word/PDF) into XML skeletons compliant with eCTD 4.0/3.2.2.
- Supports module auto-recognition and mapping to m1–m5 based on content.
- Includes a command-line interface with options for output path, module, region, and validation.
- Extracts document hierarchy, metadata, and generates master index and per-module XML files with MD5 checksums.
- Provides sample commands, reference materials, and workflow guidance for consistent execution.
元数据
常见问题
eCTD XML Compiler 是什么?
Automatically convert uploaded drug application documents (Word/PDF) into XML skeleton structure compliant with eCTD 4.0/3.2.2 specifications. 它是一个面向 Claude Code / OpenClaw 的 AI Agent Skill 插件,目前累计下载 90 次。
如何安装 eCTD XML Compiler?
在 OpenClaw 或 Claude Code 对话框中运行命令「/install ectd-xml-compiler」即可一键安装,无需额外配置。
eCTD XML Compiler 是免费的吗?
是的,eCTD XML Compiler 完全免费,采用 MIT-0 许可证,可自由下载、安装和使用。
eCTD XML Compiler 支持哪些平台?
eCTD XML Compiler 跨平台运行,可在任意部署了 OpenClaw / Claude Code 的环境中使用(cross-platform)。
谁开发了 eCTD XML Compiler?
由 AIpoch(@aipoch-ai)开发并维护,当前版本 v1.0.0。
推荐 Skills