import os import re import uuid import sys from datetime import datetime # UTF-8 좜λ ₯ 보정 if sys.stdout.encoding != 'utf-8': import io sys.stdout = io.TextIOWrapper(sys.stdout.buffer, encoding='utf-8') base_dir = r"e:\Wiki\2nd" raw_dir = os.path.join(base_dir, "00_Raw", "2026-04-20") wiki_base = os.path.join(base_dir, "10_Wiki", "πŸ’‘ Topics") batch_files = [ "3D Gaussian Splatting (3DGS).md", "3D Web-based HMI.md", "ABA(Applied Behavior Analysis).md", "Abstract Syntax Tree (AST).md", "Accessibility (A11y).md", "Addiction Neuroscience.md", "Adaptive-Learning-Systems.md", "Adversarial Attack (μ λŒ€μ  곡격).md", "ACL-Injury-Prevention-Protocols.md", "API-First Architecture.md" ] mapping = { "3D Gaussian Splatting (3DGS).md": "Graphics & Performance", "3D Web-based HMI.md": "Automation & Industry", "ABA(Applied Behavior Analysis).md": "Psychology & Behavior", "Abstract Syntax Tree (AST).md": "Programming & Language", "Accessibility (A11y).md": "Design & Experience", "Addiction Neuroscience.md": "Psychology & Behavior", "Adaptive-Learning-Systems.md": "Education & AI", "Adversarial Attack (μ λŒ€μ  곡격).md": "Security & AI", "ACL-Injury-Prevention-Protocols.md": "Health & Science", "API-First Architecture.md": "Software Architecture" } def wikify(filename): raw_path = os.path.join(raw_dir, filename) if not os.path.exists(raw_path): print(f"File not found: {raw_path}") return with open(raw_path, "r", encoding="utf-8") as f: content = f.read() title_match = re.search(r'^#\s*\[\[(.*?)\]\]', content, re.M) if not title_match: title_match = re.search(r'^\[\[(.*?)\]\]', content, re.M) title = title_match.group(1) if title_match else filename.replace(".md", "") sub_folder = mapping.get(filename, "Uncategorized") category_path = f"10_Wiki/πŸ’‘ Topics/{sub_folder}" # Extract sections summary_match = re.search(r'##?\s*πŸ“Œ\s*Brief Summary\n(.*?)(?=\n##|$)', content, re.S) summary = summary_match.group(1).strip() if summary_match else "" core_match = re.search(r'##?\s*πŸ“–\s*Core Content\n(.*?)(?=\n##|$)', content, re.S) core = core_match.group(1).strip() if core_match else "" conn_match = re.search(r'##?\s*πŸ”—\s*Knowledge Connections\n(.*?)(?=\n##|$)', content, re.S) conn = conn_match.group(1).strip() if conn_match else "" doc_id = f"P-REINFORCE-AI-{uuid.uuid4().hex[:6].upper()}" today = datetime.now().strftime("%Y-%m-%d") wiki_content = f"""--- id: {doc_id} category: "[[{category_path}]]" confidence_score: 0.95 tags: [] last_reinforced: {today} github_commit: "[P-Reinforce] Batch 9 - Wikified {title}" --- # [[{title}]] ## πŸ“Œ ν•œ 쀄 톡찰 (The Karpathy Summary) > {summary} ## πŸ“– κ΅¬μ‘°ν™”λœ 지식 (Synthesized Content) {core} ## ⚠️ λͺ¨μˆœ 및 μ—…λ°μ΄νŠΈ (Contradictions & RL Update) - **κ³Όκ±° λ°μ΄ν„°μ™€μ˜ 좩돌:** μ‹ κ·œ λ¬Έμ„œλ‘œ, κΈ°μ‘΄ μ •λ³΄μ™€μ˜ 좩돌 뢄석 μ˜ˆμ •. - **μ •μ±… λ³€ν™”:** {sub_folder} μΉ΄ν…Œκ³ λ¦¬μ˜ 지식 연결망 κ°•ν™”λ₯Ό μœ„ν•œ ν‘œμ€€ μœ„ν‚€ν™” 적용. ## πŸ”— 지식 μ—°κ²° (Graph) {conn} - Raw Source: [[00_Raw/2026-04-20/{filename}]] --- """ target_dir = os.path.join(base_dir, category_path.replace("/", os.sep)) if not os.path.exists(target_dir): os.makedirs(target_dir) target_path = os.path.join(target_dir, f"{title}.md") with open(target_path, "w", encoding="utf-8") as f: f.write(wiki_content) print(f"Processed: {filename} -> {target_path}") if __name__ == "__main__": for f in batch_files: wikify(f)