|
import gradio as gr |
|
from datasets import load_dataset |
|
from rapidfuzz import process, fuzz |
|
|
|
|
|
|
|
|
|
ds = load_dataset( |
|
"nyuuzyou/clker-svg", |
|
split="train", |
|
streaming=True, |
|
) |
|
|
|
records = [] |
|
for ex in ds: |
|
records.append( |
|
{ |
|
"id": ex["id"], |
|
"title": ex["title"] or "", |
|
"tags": " ".join(ex["tags"] or []), |
|
"svg": ex["svg_content"], |
|
"url": ex["download_url"], |
|
} |
|
) |
|
|
|
|
|
|
|
|
|
def search_svg(query: str, top_k: int): |
|
if not query.strip(): |
|
return "⚠️ 검색어를 입력하세요.", None |
|
|
|
|
|
choices = {i: f"{r['title']} {r['tags']}" for i, r in enumerate(records)} |
|
|
|
|
|
matched = process.extract( |
|
query, |
|
choices, |
|
scorer=fuzz.WRatio, |
|
limit=int(top_k), |
|
) |
|
|
|
html_snippets = [] |
|
for _choice_text, score, idx in matched: |
|
r = records[idx] |
|
svg_html = ( |
|
"<div style='border:1px solid #ddd;margin:8px;padding:8px'>" |
|
f"<strong>{r['title']}</strong> " |
|
f"(score {score})<br>" |
|
f"<em>{r['tags']}</em><br>" |
|
f"<a href='{r['url']}' target='_blank'>원본 다운로드</a><br>" |
|
f"{r['svg']}" |
|
"</div>" |
|
) |
|
html_snippets.append(svg_html) |
|
|
|
return "", "\n".join(html_snippets) |
|
|
|
|
|
|
|
|
|
with gr.Blocks(title="Clker SVG 검색") as demo: |
|
gr.Markdown("## 🔍 Clker.com SVG Public-Domain Clipart 검색") |
|
with gr.Row(): |
|
query_box = gr.Textbox(label="검색어", placeholder="예: cat, tree, ...") |
|
top_slider = gr.Slider(1, 50, value=10, step=1, label="결과 개수") |
|
warning_md = gr.Markdown() |
|
output_html = gr.HTML() |
|
|
|
query_box.submit( |
|
fn=search_svg, |
|
inputs=[query_box, top_slider], |
|
outputs=[warning_md, output_html], |
|
) |
|
|
|
if __name__ == "__main__": |
|
demo.launch() |
|
|