Metadata-Version: 2.1
Name: ssprompt
Version: 0.0.2
Summary: A LLM Prompt distribution tool
Author: ptonlix
Author-email: baird0917@163.com
Requires-Python: >=3.10,<4.0
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Requires-Dist: cleo (>=2.0.1,<3.0.0)
Requires-Dist: importlib-metadata (>=6.8,<7.0)
Requires-Dist: packaging (>=23.1,<23.2)
Requires-Dist: pydantic (==1.10.*)
Requires-Dist: pyyaml (>=6.0,<6.1)
Requires-Dist: requests (>=2.31.0,<3.0.0)
Requires-Dist: tqdm (>=4.66.1,<5.0.0)
Description-Content-Type: text/markdown

# 🌌 ssprompt
简体中文 | [English]((./README-en.md))
<p>
	<p align="center">
		<img height=120 src="https://img.gejiba.com/images/e1945208195b199bd244431fd2a6efa0.png">
	</p>
	<p align="center">
		<img src="https://img.gejiba.com/images/605bd1bcc1a14f803f1d8f68b8c1c892.png"><br>
		<b face="雅黑">Change the world, even a little bit.</b>
	<p>
</p>
<p align="center">
<img alt=" Python" src="https://img.shields.io/badge/Python-3.10%2B-blue"/>
<img alt="cleo" src="https://img.shields.io/badge/cleo-2.0.1-yellowgreen"/>
<img alt="license" src="https://img.shields.io/badge/license-Apache-lightgrey"/>
</p>

>自从OpenAI掀起了一轮新的AI革命，国内外众多玩家入场接受时代洗礼，一时间LLM相关技术井喷，而提示工程( prompt engineering )就在其中。   
它就像是为大语言模型（LLM）设计的"语言游戏"。通过这个"游戏"，我们可以更有效地引导 LLM 来处理问题。在真正的通用智能到来前，基于当前的LLM范式，要充分发挥LLM的优势，Prompt设计越来越复杂化，进一步Prompt的代码化，模块化会越发明显，同时写prompt将会成为AI时代人的基本技能。  
基于此，我构思创作了ssprompt，希望每个人都能利用Prompt，享受AI时代红利

## 🚀 Quick Install
### 系统依赖
Ssprompt requires Python 3.10+ 

⭐ 支持多平台使用，满足广大Prompt Engineer💻
### pip安装
```shell
pip install ssprompt
```
### Linux, macOS, Windows (WSL)
```shell
curl -sSL https://raw.githubusercontent.com/ptonlix/ssprompt/main/install.py | python3 -
```
### Windows (Powershell)
```shell
(Invoke-WebRequest -Uri https://raw.githubusercontent.com/ptonlix/ssprompt/main/install.py -UseBasicParsing).Content | py -
```

## 🔔 What it can do?
**ssprompt**是一个Prompt分发管理工具，定义了一套Prompt分发规则  
支持创建Prompt工程和拉取[Prompt Hub](https://github.com/ptonlix/PromptHub)上对应Prompt的工程文件到本地工程


![Ssprompt Interaction](https://img.gejiba.com/images/2cb6f408c1de52e3d2e8c1fb603254ce.png)

_注：以下为 0.1.0 第一版ssprompt的内容介绍，项目还在持续完善，如有疏漏或不足之处请包涵了解，谢谢~_

![ssprompt show](https://img.gejiba.com/images/343c5e8b220f5e498f1a192ece4b14d4.gif)

### 命令介绍 
- ssprompt new   ->  新建一个新的Prompt工程，指定工程目录，Prompt类型等参数
- ssprompt init  ->  基于当前目录，引导创建一个Prompt工程
- ssprompt add   ->  添加一个不同Prompt类型和相关依赖到metafile，并生成相应的Prompt工程目录（工程配置文件）
- ssprompt show  ->  展示本地Prompt工程的基本信息（metafile）或拉取PromptHub上对应工程的信息
- ssprompt pull  ->  拉取远端工程到本地项目中，相关工程可以引用Prompt文件或代码
- ssprompt list  ->  展示当前版本ssprompt支持的命令
- ssprompt about ->  展示ssprompt的介绍和版本信息
- ssprompt version -> 展示ssprompt的版本信息

更多命令参数详情，请使用`ssprompt [command] -h`进一步了解

### Metafile介绍
ssprompt通过定义prompt工程的Meta文件来约束管理Prompt分发规则和内容  
ssprompt关于prompt定义了四种类型的Prompt
- Text
- Json
- Yaml
- Python

可以按需生成对应的Prompt上传到PromptHub进行分发  
metafile以Prompt工程名称命名,如prompt_project.yaml ，是ssprompt管理Prompt分发的关键

注：上述类型结合参考了langchain和haystack
```yaml
#Prompt工程基础信息
meta:
  name: open #工程名称
  author: 
  - ptonlix <baird0917@163.com>
  description: ''
  license: MIT #Prompt工程遵循的协议
  llm:    #Prompt支持的LLM模型
  - gpt-3.5-turbo 
  readme_format: md #Readme文件格式
  tag:  #Prompt工程相关类型领域，如question-generation common为公共领域
  - common
  version: 0.1.0 #版本号

#Text类型的Prompt
text_prompt:
  dirname: text #目录名称, 默认为text

#Json类型的Prompt
json_prompt:
  dirname: json #目录名称，默认为json
  list:                  #支持多个json类型子工程
  - dependencies:   
      langchain: 0.0.266 #json解析依赖的三方库版本号，如langchain等
    name: example        #子工程名，对应生成工程目录名

#Yaml类型的prompt
yaml_prompt: 
  dirname: yaml #目录名称，默认为yaml
  list:					 #支持多个yaml类型子工程
  - dependencies:		
      langchain: 0.0.266 #yaml解析依赖的三方库版本号，如langchain等
    name: example		 #子工程名，对应生成工程目录名

#Python类型的Prompt
python_prompt:	#目录名称，默认为yaml
  dirname: python		 #目录名称，默认为yaml
  list: 				 #支持多个yaml类型子工程
  - dependencies:
      langchain: 0.0.266 #Python库引用的三方库版本号，如langchain等
    name: example		 #子工程名，对应生成工程目录名
```

#### 版本依赖规则
当前版本支持三种版本依赖规则  
* Caret requirements  
	- ^1.2.3
* Tilde requirements  
	- ~1.2.3
* Wildcard requirements 
	- 1.2.*
* laster                
	- 支持最新版本

## 🌊 PromptHub
目前ssprompt生成的Prompt工程，依赖Git管理，通过Git将Prompt工程上传到Git仓库以便ssprompt拉取引用

当前默认PromptHub托管在GitHub [ptonlix/PromptHub](https://github.com/ptonlix/PromptHub)

目前PromptHub的Prompt工程还在持续建设中 🕜

后续会陆续收集和建设更多Prompt工程发布到我们PromptHub ☁️

🍗 欢迎大家上传自己的Prompt到PromptHub，共建一个开源的Prompt生态
#### GitHub Token
由于目前GitHub API请求访问限制，不采用authentication访问，会限制一个小时只能访问60次，导致使用ssprompt频繁拉取工程时存在403限制请求

**推荐在使用ssprompt时，设置GitHub Personal access tokens到环境变量**
```shell
export GITHUB_ACCESS_KEY=`Your GitHub Token`
```


## 🚩 Roadmap
- [x] 搭建ssprompt初步框架，完善基本功能
- [ ] 完善ssprompt命令  
   - [ ] pull命令支持拉取特定类型Prompt工程到本地
   - [ ] show命令支持展示更多PromptHub信息
- [ ] 搭建和完善PromptHub
	- [ ] 收集全网优秀的Prompt案例，使用ssprompt 构建工程并上传到PromptHub
- [ ] ssprompt网站与文档建设
	- [ ] ssprompt 说明文档
	- [ ] PromptHub 网站建设


## 🌏 项目交流讨论
<img height=240 src="https://img.gejiba.com/images/f0cf4242e87615dff574806169f9732a.png"/>

🎉 扫码联系作者，如果你也对本项目感兴趣，欢迎加入ssprompt项目群参与讨论交流。

## 💥 贡献
欢迎大家贡献力量，一起共建ssprompt，您可以做任何有益事情
- 报告错误
- 建议改进
- 文档贡献
- 代码贡献  
...  
👏👏👏


