weave.StringPrompt 또는 weave.MessagesPrompt 클래스를 사용할 수 있습니다. 더 복잡한 요구 사항이 있는 경우, 해당 클래스나 기본 클래스인 weave.Prompt를 상속받아 format 메소드를 오버라이드할 수 있습니다.
weave.publish를 사용하여 이러한 오브젝트 중 하나를 게시하면, Weave 프로젝트의 Prompts 페이지에 표시됩니다.
StringPrompt
StringPrompt는 시스템 메시지, 사용자 쿼리 또는 LLM에 대한 독립형 텍스트 입력에 사용할 수 있는 단일 문자열 프롬프트를 로그합니다. 여러 메시지가 오가는 대화의 복잡성이 필요하지 않은 개별 프롬프트 문자열을 관리할 때는 StringPrompt를 사용하는 것이 좋습니다.
- Python
- TypeScript
MessagesPrompt
MessagesPrompt를 사용하면 멀티턴 대화와 채팅 기반 프롬프트를 로그할 수 있습니다. 이는 전체 대화 흐름을 나타내는 메시지 오브젝트 배열(“system”, “user”, “assistant”와 같은 역할 포함)을 저장합니다. 여러 메시지에 걸쳐 컨텍스트를 유지하거나, 특정 대화 패턴을 정의하거나, 재사용 가능한 대화 템플릿을 만들어야 하는 채팅 기반 LLM의 경우 이 방식을 권장합니다.
- Python
- TypeScript
파라미터화된 프롬프트 (Parameterizing prompts)
StringPrompt와 MessagesPrompt 모두 파라미터화를 통한 동적 콘텐츠를 지원합니다. 이를 통해 런타임에 다른 값으로 채울 수 있는 플레이스홀더({variable} 구문 사용)가 포함된 유연하고 재사용 가능한 프롬프트 템플릿을 만들 수 있습니다. 이는 일관된 구조를 유지하면서 다양한 입력, 사용자 데이터 또는 컨텍스트에 프롬프트를 적응시켜야 하는 확장 가능한 애플리케이션을 빌드할 때 유용합니다. format() 메소드는 이러한 플레이스홀더를 실제 값으로 바꾸기 위해 키-값 쌍을 인자로 받습니다.
- Python
- TypeScript
MessagesPrompt에서도 작동합니다.
- Python
- TypeScript
프롬프트 버전 확인 및 비교
Weave는 프롬프트의 모든 버전을 자동으로 추적하여 프롬프트가 어떻게 발전해 왔는지에 대한 전체 이력을 생성합니다. 이 버전 관리 시스템은 프롬프트 엔지니어링 워크플로우에 매우 중요하며, 안전하게 실험하고 어떤 변화가 성능을 개선하거나 저하시켰는지 추적하고 필요할 때 이전 버전으로 쉽게 롤백할 수 있게 해줍니다. 동일한 이름으로 다른 내용의 프롬프트를 게시할 때마다 Weave는 이전 버전을 모두 보존하면서 새 버전을 생성합니다. UI에서 프롬프트 버전을 확인하려면 다음 단계를 따르세요.- UI에서 프로젝트를 열고 왼쪽 메뉴에서 Assets 버튼을 클릭합니다. Assets 페이지가 열립니다.
- Assets 페이지에서 Prompts를 클릭합니다. 프로젝트의 프롬프트가 나열된 Prompts 페이지가 열립니다.
- Versions 열에서 확인하려는 프롬프트의 (x) Versions를 클릭합니다. 프롬프트 버전 목록이 열립니다.

- (선택 사항) 목록에 있는 프롬프트 옆의 체크박스를 클릭한 다음 Compare 버튼을 클릭하여 프롬프트 버전을 비교할 수 있습니다. 이를 통해 프롬프트 간의 차이점(diff)을 확인할 수 있습니다.
