쪽지발송 성공
Click here
재능넷 이용방법
재능넷 이용방법 동영상편
가입인사 이벤트
판매 수수료 안내
안전거래 TIP
재능인 인증서 발급안내

🌲 지식인의 숲 🌲

🌳 디자인
🌳 음악/영상
🌳 문서작성
🌳 번역/외국어
🌳 프로그램개발
🌳 마케팅/비즈니스
🌳 생활서비스
🌳 철학
🌳 과학
🌳 수학
🌳 역사
해당 지식과 관련있는 인기재능

안녕하세요 . 고객님들이 믿고 사용할 수 있는 프로그램을 개발하기 위해 항상 노력하고있습니다.각 종 솔루션에 대한 상담이 가능하며 , &nb...

  Arduino로 어떤 것이라도 개발해드립니다.​개발자 경력  ​프로그래밍 고교 졸업 아주대학교 전자공학과 휴학중 ...

현재 한국디지털미디어고등학교에 재학중인 학생입니다. 아드이노는 중 1 처음 접하였으며  횟수로 5년동안 아두이노를 해오...

안녕하세요.안드로이드 앱/라즈베리파이/ESP8266/32/ 아두이노 시제품 제작 외주 및 메이커 취미 활동을 하시는 분들과 아두이노 졸업작품을 진행...

Clojure의 zippers: 트리 구조 효율적으로 탐색하기

2024-11-09 15:27:42

재능넷
조회수 453 댓글수 0

Clojure의 zippers: 트리 구조 효율적으로 탐색하기 🌳🔍

 

 

안녕, 친구들! 오늘은 정말 흥미진진한 주제로 찾아왔어. 바로 Clojure의 zippers야! 🎉 이게 뭐냐고? 걱정 마, 지금부터 아주 쉽고 재미있게 설명해줄게. 마치 우리가 숲속에서 보물찾기를 하는 것처럼 말이야! 🌲💎

그런데 말이야, 우리가 이렇게 재미있게 프로그래밍에 대해 이야기하고 있지만, 사실 프로그래밍 실력을 향상시키는 건 쉽지 않은 일이야. 혹시 프로그래밍 멘토링이 필요하다면 재능넷(https://www.jaenung.net)을 한 번 방문해봐. 거기서 다양한 프로그래밍 전문가들을 만날 수 있을 거야!

자, 이제 본격적으로 Clojure의 zippers에 대해 알아보자구!

Zippers란 뭘까? 🤔

zippers... 이름부터 좀 특이하지? 혹시 지퍼를 떠올렸니? 맞아, 실제로 지퍼와 비슷한 개념이야! 👖

Zippers는 트리 구조를 효율적으로 탐색하고 수정할 수 있게 해주는 도구야. 마치 지퍼가 옷을 쉽게 열고 닫을 수 있게 해주는 것처럼, zippers는 트리 구조를 쉽게 '열고 닫을' 수 있게 해준다고 볼 수 있지.

근데 잠깐, 트리 구조가 뭐냐고? 😅 걱정 마, 이것도 쉽게 설명해줄게!

트리 구조란? 데이터를 계층적으로 저장하는 방식이야. 마치 가족 족보나 회사의 조직도처럼 말이야. 루트(뿌리)에서 시작해서 가지가 뻗어나가는 모양이지.

자, 이제 트리 구조가 뭔지 알았으니, zippers가 왜 필요한지 이해할 수 있을 거야. 트리 구조는 정말 유용하지만, 때로는 이 구조를 탐색하거나 수정하는 게 꽤 복잡할 수 있거든. 그래서 zippers가 등장한 거지!

zippers를 사용하면 마치 트리 구조 안에서 자유롭게 돌아다니는 것 같은 느낌을 받을 수 있어. 위로 올라가거나, 아래로 내려가거나, 옆으로 이동하거나... 정말 편리하지? 🚶‍♂️🌳

그럼 이제 Clojure에서 zippers를 어떻게 사용하는지 자세히 알아볼까? 준비됐니? 출발~! 🚀

Clojure에서 Zippers 시작하기 🎬

자, 이제 Clojure에서 zippers를 어떻게 사용하는지 알아볼 차례야. 먼저, Clojure에서 zippers를 사용하려면 clojure.zip 네임스페이스를 불러와야 해. 이렇게 말이야:

(ns my-awesome-project.core
  (:require [clojure.zip :as zip]))

이렇게 하면 zip이라는 별칭으로 clojure.zip 네임스페이스의 모든 함수를 사용할 수 있어. 멋지지? 😎

그럼 이제 간단한 트리 구조를 만들어볼까? 예를 들어, 이런 구조를 생각해보자:

(def my-tree
  [:a
   [:b
    [:c]
    [:d]]
   [:e
    [:f]
    [:g]]])

이 트리는 이런 모양이야:

트리 구조 시각화 a b e c d f g

와! 정말 예쁜 트리가 만들어졌어! 🌳 이제 이 트리를 가지고 놀아볼 시간이야.

zippers를 사용하려면 먼저 이 트리를 zipper로 변환해야 해. Clojure에서는 zip/vector-zip 함수를 사용해서 벡터로 된 트리를 zipper로 만들 수 있어. 이렇게:

(def my-zipper (zip/vector-zip my-tree))

짜잔! 🎉 이제 우리는 zipper를 가지고 있어. 이 zipper를 사용해서 트리를 자유롭게 돌아다닐 수 있지. 마치 트리 안에서 모험을 떠나는 것 같아, 그렇지? 😄

다음 섹션에서는 이 zipper를 가지고 어떤 재미있는 일들을 할 수 있는지 알아볼 거야. 준비됐니? 모험을 떠나볼까! 🚀🌟

Zipper로 트리 탐험하기 🧭🌳

자, 이제 우리는 zipper를 가지고 있어. 그럼 이걸로 뭘 할 수 있을까? 음... 트리 구조를 탐험할 수 있지! 마치 숲속을 모험하는 것처럼 말이야. 🏞️

Clojure의 zipper는 우리에게 여러 가지 '이동' 함수를 제공해. 이 함수들을 사용하면 트리를 자유롭게 돌아다닐 수 있어. 어떤 함수들이 있는지 한번 볼까?

  • 🚶‍♂️ zip/down: 자식 노드로 이동해
  • 🏃‍♀️ zip/up: 부모 노드로 올라가
  • 👈 zip/left: 왼쪽 형제 노드로 이동해
  • 👉 zip/right: 오른쪽 형제 노드로 이동해
  • 🔄 zip/next: 다음 노드로 이동해 (깊이 우선 탐색)
  • 🔙 zip/prev: 이전 노드로 이동해

와! 정말 많은 함수가 있지? 이 함수들을 사용하면 트리 구조를 마음대로 돌아다닐 수 있어. 멋지지 않아? 😎

자, 그럼 이제 우리의 트리를 탐험해볼까? 먼저 루트 노드에서 시작해서 첫 번째 자식 노드로 내려가 보자:

(-> my-zipper
    zip/down)

이렇게 하면 :b 노드로 이동하게 돼. 그럼 이제 오른쪽 형제 노드로 이동해볼까?

(-> my-zipper
    zip/down
    zip/right)

짜잔! 🎉 이제 :e 노드에 도착했어. 재미있지? 마치 트리를 타고 노는 것 같아!

근데 말이야, 이렇게 노드를 이동할 때마다 새로운 zipper가 반환된다는 걸 기억해야 해. 원래의 zipper는 변하지 않아. 이건 Clojure의 불변성(immutability) 원칙 때문이야. 조금 어려운 개념일 수 있지만, 이 덕분에 우리는 안전하게 데이터를 다룰 수 있어.

불변성이란 한 번 만들어진 데이터는 변경되지 않는다는 개념이야. 마치 한 번 쓴 일기장 페이지를 절대 고치지 않는 것처럼 말이야. 새로운 내용을 쓰고 싶다면? 새 페이지를 사용하면 되지! 👍

자, 이제 우리의 트리 탐험을 계속해볼까? 이번에는 zip/next 함수를 사용해서 트리를 순회해볼 거야. 이 함수는 깊이 우선 탐색(DFS)을 사용해서 트리의 모든 노드를 방문해. 뭔가 어려워 보이지만, 걱정 마! 천천히 따라와 봐.

(loop [z my-zipper]
  (if (zip/end? z)
    (println "트리 탐험 끝!")
    (do
      (println (zip/node z))
      (recur (zip/next z)))))

이 코드를 실행하면 우리 트리의 모든 노드를 순서대로 볼 수 있어. 마치 트리의 모든 가지를 하나하나 살펴보는 것 같지? 🕵️‍♀️

결과는 이렇게 나올 거야:

:a
:b
:c
:d
:e
:f
:g
트리 탐험 끝!

와! 우리가 트리의 모든 노드를 방문했어! 🎊 정말 대단하지 않아?

이렇게 zippers를 사용하면 복잡한 트리 구조도 쉽게 탐색할 수 있어. 마치 미로 같은 데이터 구조에서도 길을 잃지 않고 원하는 곳으로 갈 수 있는 거지. 👣🗺️

그런데 말이야, 이렇게 트리를 탐색하는 기술은 실제 프로그래밍에서 정말 유용해. 예를 들어, HTML 문서를 파싱하거나, 파일 시스템을 탐색하거나, 심지어 인공지능의 의사결정 트리를 만들 때도 이런 기술이 사용된다구!

혹시 이런 고급 프로그래밍 기술에 대해 더 배우고 싶다면, 재능넷(https://www.jaenung.net)에서 전문가의 도움을 받아볼 수 있어. 거기에는 다양한 분야의 전문가들이 있어서, 네가 원하는 주제에 대해 깊이 있게 배울 수 있을 거야. 😊

자, 이제 우리는 zipper로 트리를 탐험하는 방법을 배웠어. 다음 섹션에서는 이 zipper를 사용해서 트리를 수정하는 방법을 알아볼 거야. 준비됐니? 더 재미있는 내용이 기다리고 있어! 🚀✨

Zipper로 트리 수정하기 ✏️🌳

자, 이제 우리는 zipper로 트리를 돌아다니는 방법을 알게 됐어. 근데 말이야, zipper는 단순히 트리를 탐색하는 것뿐만 아니라 수정할 수도 있어! 😲 마치 마법 지팡이로 나무를 변형시키는 것처럼 말이야. 🧙‍♂️✨

Clojure의 zipper는 트리를 수정하기 위한 여러 가지 함수를 제공해. 어떤 함수들이 있는지 한번 볼까?

  • ✏️ zip/edit: 현재 노드를 수정해
  • zip/insert-left: 현재 노드의 왼쪽에 새 노드를 추가해
  • zip/insert-right: 현재 노드의 오른쪽에 새 노드를 추가해
  • 🔽 zip/insert-child: 현재 노드의 자식으로 새 노드를 추가해
  • ✂️ zip/remove: 현재 노드를 제거해
  • 🔄 zip/replace: 현재 노드를 새로운 노드로 교체해

와! 정말 많은 함수가 있지? 이 함수들을 사용하면 트리를 마음대로 바꿀 수 있어. 멋지지 않아? 😎

자, 그럼 이제 우리의 트리를 수정해볼까? 먼저 :b 노드를 :awesome-b로 바꿔보자:

(-> my-zipper
    zip/down
    (zip/edit (fn [node] :awesome-b))
    zip/root)

이 코드는 다음과 같은 일을 해:

  1. 루트 노드에서 시작해 (my-zipper)
  2. 첫 번째 자식 노드로 내려가고 (zip/down)
  3. 그 노드를 :awesome-b로 수정하고 (zip/edit)
  4. 수정된 전체 트리를 반환해 (zip/root)

결과는 이렇게 될 거야:

[:a
 [:awesome-b
  [:c]
  [:d]]
 [:e
  [:f]
  [:g]]]

와! 우리가 트리를 성공적으로 수정했어! 🎉 :b:awesome-b로 바뀌었지? 정말 대단하지 않아?

이번에는 새로운 노드를 추가해볼까? :e 노드의 자식으로 :h를 추가해보자:

(-> my-zipper
    zip/down
    zip/right
    (zip/insert-child :h)
    zip/root)

이 코드는:

  1. 루트 노드에서 시작해
  2. 첫 번째 자식 노드로 내려가고 (:b 또는 :awesome-b)
  3. 오른쪽 형제 노드로 이동하고 (:e)
  4. :h를 새로운 자식으로 추가하고
  5. 수정된 전체 트리를 반환해

결과는 이렇게 될 거야:

[:a
 [:awesome-b
  [:c]
  [:d]]
 [:e
  :h
  [:f]
  [:g]]]

와우! 우리가 트리에 새로운 노드를 추가했어! 🌱 마치 나무에 새로운 가지가 자라난 것 같지 않아?

이렇게 zippers를 사용하면 복잡한 트리 구조도 쉽게 수정할 수 있어. 마치 레고 블록을 조립하는 것처럼, 데이터 구조를 원하는 대로 만들 수 있는 거지. 🧱👷‍♂️

그런데 말이야, 이런 트리 수정 기술은 실제 프로그래밍에서 정말 유용해. 예를 들어, XML 문서를 수정하거나, 파일 시스템의 구조를 변경하거나, 심지어 게임에서 기술 트리를 구현할 때도 이런 기술이 사용된다구!

Clojure의 zippers는 정말 강력한 도구야. 복잡한 데이터 구조를 다룰 때 정말 큰 도움이 돼. 하지만 이걸 제대로 사용하려면 연습이 필요해. 마치 악기를 연주하는 것처럼, 처음에는 어려울 수 있지만 계속 연습하다 보면 점점 더 능숙해질 거야. 🎸🎹

혹시 이런 고급 프로그래밍 기술에 대해 더 배우고 싶다면, 재능넷(https://www.jaenung.net)에서 Clojure 전문가를 찾아볼 수 있어. 전문가의 도움을 받으면 더 빠르게 실력을 향상시킬 수 있을 거야. 😊

자, 이제 우리는 zipper로 트리를 수정하는 방법도 배웠어. 다음 섹션에서는 이 zipper를 사용해서 좀 더 복잡한 작업을 해볼 거야. 준비됐니? 더 흥미진진한 내용이 기다리고 있어! 🚀🌟

Zipper로 복잡한 작업 수행하기 🧠🌳

자, 이제 우리는 zipper로 트리를 탐색하고 수정하는 방법을 알게 됐어. 근데 말이야, zipper의 진짜 힘은 이런 기본적인 작업을 넘어서 복잡한 작업을 수행할 때 나타나. 마치 레고 블록으로 복잡한 우주선을 만드는 것처럼 말이야! 🚀👨‍🚀

이번에는 좀 더 복잡한 작업을 해볼 거야. 우리의 트리에서 모든 leaf 노드(자식이 없는 노드)를 찾아서 대문자로 바꿔보자. 어때, 재미있을 것 같지? 😄

먼저, 우리가 사용할 함수를 만들어볼게:

(defn uppercase-leaves [zipper]
  (loop [loc zipper]
    (if (zip/end? loc)
      (zip/root loc)
      (recur (zip/next (if (zip/branch? loc)
                         loc
                         (zip/edit loc #(-> % name .toUpperCase keyword))))))))

우와, 조금 복잡해 보이지? 😅 걱정 마, 천천히 설명해줄게:

  1. looprecur를 사용해서 트리를 순회해.
  2. zip/end?로 트리의 끝에 도달했는지 확인해.
  3. 끝에 도달했다면, zip/root로 수정된 전체 트리를 반환해.
  4. 아직 끝이 아니라면, 현재 노드가 branch(자식이 있는 노드)인지 확인해.
  5. branch가 아니라면(즉, leaf 노드라면) 노드를 대문자로 바꿔.
  6. zip/next로 다음 노드로 이동하고 과정을 반복해.

이제 이 함수를 우리의 트리에 적용해보자:

(uppercase-leaves (zip/vector-zip my-tree))

결과는 이렇게 될 거야:

[:a
 [:b
  [:C]
  [:D]]
 [:e
  [:F]
  [:G]]]

와! 모든 leaf 노드가 대문자로 바뀌었어! 🎉 정말 대단하지 않아?

이런 식으로 zipper를 사용하면 복잡한 트리 구조에서도 원하는 작업을 쉽게 수행할 수 있어. 마치 마법사가 주문을 외워 세상을 변화시키는 것처럼 말이야! 🧙‍♂️✨

그런데 말이야, 이런 복잡한 트리 조작 기술은 실제 프로그래밍에서 정말 유용해. 예를 들어, 복잡한 JSON 데이터를 처리하거나, 프로그래밍 언어의 구문 트리를 분석하고 변환할 때 이런 기술이 사용돼. 심지어 인공지능 분야에서 결정 트리를 만들고 수정할 때도 이런 방식을 사용한다구! 🤖🌳

Clojure의 zippers는 단순히 데이터 구조를 다루는 도구를 넘어서, 우리가 문제를 바라보는 방식을 바꿔주는 강력한 추상화야. 복잡한 구조를 간단하게 다룰 수 있게 해주니까. 마치 현미경으로 세포의 구조를 자세히 들여다보는 것처럼, zippers는 우리가 데이터의 구조를 더 깊이 이해하고 조작할 수 있게 해주지. 🔬🧬

자, 이제 우리가 배운 걸 정리해볼까?

  1. Zippers는 트리 구조를 효율적으로 탐색하고 수정할 수 있게 해주는 도구야.
  2. Clojure에서는 clojure.zip 네임스페이스를 통해 zippers를 사용할 수 있어.
  3. Zippers를 사용하면 트리를 자유롭게 돌아다니며 노드를 수정하거나 추가, 삭제할 수 있어.
  4. 복잡한 트리 조작 작업도 zippers를 사용하면 간단하게 구현할 수 있어.

와! 정말 많은 걸 배웠지? 👏👏👏

그런데 말이야, 이렇게 복잡한 개념을 혼자 공부하는 건 쉽지 않을 수 있어. 때로는 전문가의 도움이 필요할 때도 있지. 그럴 때 재능넷(https://www.jaenung.net)을 활용해보는 건 어떨까? 거기서 Clojure 전문가를 만나면, 이런 고급 기술에 대해 더 깊이 있게 배울 수 있을 거야. 😊

자, 이제 우리의 zipper 여행이 거의 끝나가고 있어. 마지막으로, zippers를 사용할 때 주의해야 할 점들에 대해 이야기해볼까? 🚦🛑

Zippers 사용 시 주의사항 ⚠️🌳

자, 이제 우리는 zippers의 강력함에 대해 잘 알게 됐어. 하지만 모든 강력한 도구가 그렇듯, zippers도 조심해서 사용해야 해. 마치 슈퍼히어로의 능력처럼, 큰 힘에는 큰 책임이 따르는 법이지! 🦸‍♂️

여기 zippers를 사용할 때 주의해야 할 몇 가지 사항이 있어:

  1. 성능에 주의하세요: Zippers는 매우 유용하지만, 큰 트리에서는 성능 문제가 발생할 수 있어. 특히 zip/nextzip/prev를 사용할 때 주의가 필요해. 트리가 너무 크다면 다른 방법을 고려해보는 것도 좋아.
  2. 불변성을 기억하세요: Clojure의 zippers는 불변(immutable)이야. 즉, 수정 작업을 할 때마다 새로운 zipper가 생성돼. 이건 안전하지만, 메모리 사용에 주의해야 해.
  3. 재귀에 주의하세요: Zippers로 복잡한 재귀 함수를 만들 때는 스택 오버플로우에 주의해야 해. 가능하면 looprecur를 사용하는 것이 좋아.
  4. zipper의 상태를 잘 관리하세요: Zipper를 수정한 후에는 항상 zip/root를 호출해서 전체 트리를 얻어야 해. 수정 중간의 zipper 상태를 그대로 사용하면 예상치 못한 결과가 나올 수 있어.
  5. 테스트를 잘 작성하세요: Zippers를 사용한 코드는 복잡할 수 있어. 항상 충분한 테스트를 작성해서 코드가 예상대로 동작하는지 확인해야 해.

이런 주의사항들을 잘 기억하면서 zippers를 사용하면, 정말 강력하고 우아한 코드를 작성할 수 있을 거야. 마치 숙련된 마법사가 주문을 완벽하게 제어하는 것처럼 말이야! 🧙‍♂️✨

그리고 기억해, 프로그래밍은 계속 배우고 성장하는 과정이야. Zippers를 완벽하게 이해하고 사용하는 데는 시간이 걸릴 수 있어. 하지만 포기하지 마! 계속 연습하고 실험해보면, 언젠가는 너도 zipper의 달인이 될 수 있을 거야. 🌱➡️🌳

혹시 더 깊이 있는 내용을 배우고 싶다면, Clojure 커뮤니티에 참여해보는 것도 좋아. 다른 개발자들의 경험을 듣고 배울 수 있는 좋은 기회가 될 거야. 그리고 재능넷(https://www.jaenung.net)에서 Clojure 전문가를 찾아 1:1 멘토링을 받아보는 것도 추천해. 전문가의 조언은 네 실력 향상에 큰 도움이 될 거야. 😊

자, 이제 우리의 zipper 여행이 끝났어. 정말 긴 여정이었지만, 많은 것을 배웠길 바라. 이제 너는 Clojure의 zippers에 대해 꽤 많이 알게 됐어. 이 지식을 가지고 더 멋진 프로그램을 만들 수 있을 거야!

기억해, 프로그래밍의 세계는 끝없이 넓고 깊어. Zippers는 그저 시작일 뿐이야. 계속해서 호기심을 가지고 새로운 것을 배우고 도전해나가길 바라. 그럼 언젠가 우리 다시 만나서 더 흥미진진한 주제로 이야기를 나눌 수 있기를! 👋😊

행운을 빌어! 그리고 즐거운 코딩하세요! 🚀💻✨

관련 키워드

  • Clojure
  • Zippers
  • 트리 구조
  • 데이터 조작
  • 함수형 프로그래밍
  • 불변성
  • 재귀
  • 트리 탐색
  • 트리 수정
  • 고급 프로그래밍 기법

지적 재산권 보호

지적 재산권 보호 고지

  1. 저작권 및 소유권: 본 컨텐츠는 재능넷의 독점 AI 기술로 생성되었으며, 대한민국 저작권법 및 국제 저작권 협약에 의해 보호됩니다.
  2. AI 생성 컨텐츠의 법적 지위: 본 AI 생성 컨텐츠는 재능넷의 지적 창작물로 인정되며, 관련 법규에 따라 저작권 보호를 받습니다.
  3. 사용 제한: 재능넷의 명시적 서면 동의 없이 본 컨텐츠를 복제, 수정, 배포, 또는 상업적으로 활용하는 행위는 엄격히 금지됩니다.
  4. 데이터 수집 금지: 본 컨텐츠에 대한 무단 스크래핑, 크롤링, 및 자동화된 데이터 수집은 법적 제재의 대상이 됩니다.
  5. AI 학습 제한: 재능넷의 AI 생성 컨텐츠를 타 AI 모델 학습에 무단 사용하는 행위는 금지되며, 이는 지적 재산권 침해로 간주됩니다.

재능넷은 최신 AI 기술과 법률에 기반하여 자사의 지적 재산권을 적극적으로 보호하며,
무단 사용 및 침해 행위에 대해 법적 대응을 할 권리를 보유합니다.

© 2025 재능넷 | All rights reserved.

댓글 작성
0/2000

댓글 0개

해당 지식과 관련있는 인기재능

반드시 문의 먼저 부탁드려요저는 전국 기능경기대회(정보기술 분야) 금 출신 입니다 대회준비하며 엑셀에 있는 모든기능을 사용해 보았다고 ...

안녕하세요. 개발경력10년차 풀스택 개발자입니다. java를 기본 베이스로 하지만, 개발효율 또는 고객님의 요구에 따라 다른언어를 사용...

PCB ARTWORK (아트웍) / 회로설계 (LED조명 및 자동차 및 SMPS/ POWER)  안녕하세요. 개발자 입니다.PCB ARTWORK 을 기반으로 PCB ...

c언어c++,   erwin을 이용한 데이터베이스 설계java,    jsp,     javascript,      c#  ...

📚 생성된 총 지식 11,397 개

  • (주)재능넷 | 대표 : 강정수 | 경기도 수원시 영통구 봉영로 1612, 7층 710-09 호 (영통동) | 사업자등록번호 : 131-86-65451
    통신판매업신고 : 2018-수원영통-0307 | 직업정보제공사업 신고번호 : 중부청 2013-4호 | jaenung@jaenung.net

    (주)재능넷의 사전 서면 동의 없이 재능넷사이트의 일체의 정보, 콘텐츠 및 UI등을 상업적 목적으로 전재, 전송, 스크래핑 등 무단 사용할 수 없습니다.
    (주)재능넷은 통신판매중개자로서 재능넷의 거래당사자가 아니며, 판매자가 등록한 상품정보 및 거래에 대해 재능넷은 일체 책임을 지지 않습니다.

    Copyright © 2024 재능넷 Inc. All rights reserved.
ICT Innovation 대상
미래창조과학부장관 표창
서울특별시
공유기업 지정
한국데이터베이스진흥원
콘텐츠 제공서비스 품질인증
대한민국 중소 중견기업
혁신대상 중소기업청장상
인터넷에코어워드
일자리창출 분야 대상
웹어워드코리아
인터넷 서비스분야 우수상
정보통신산업진흥원장
정부유공 표창장
미래창조과학부
ICT지원사업 선정
기술혁신
벤처기업 확인
기술개발
기업부설 연구소 인정
마이크로소프트
BizsPark 스타트업
대한민국 미래경영대상
재능마켓 부문 수상
대한민국 중소기업인 대회
중소기업중앙회장 표창
국회 중소벤처기업위원회
위원장 표창