python中高效构建提示词

在做大模型应用项目时,经常需要处理system_prompt和user_prompt这两个提示词,对于样例、用户输入的query等需要填入。用最普通的拼接虽然很快,但是后期迭代会有些心智负担。

最近找了一个不错的方法,就是用python的.format方法,将内容动态填充到字符串中。

这个操作其实我们之前一定有过接触,就是形如类似的:

python 复制代码
name = "golemon"
print(f"I'm {name}")
print("I'm {}".format(name))

只需要在字符串中用{}包裹即可进行填充。

python 复制代码
name = "golemon"
age = 21
greeting = "Hello, my name is {} and I am {} years old.".format(name, age)

print(greeting)

在提示词中会经常出现下面形式:

python 复制代码
请按照一下格式输出:{"score":"打出的分","reason":"给出这个分数的原因"}
...
例子如下:
	{...}
	{...}

在上面形式中,我们只是将{}包裹的当作字符串,而不是要填充的内容,这个时候可以用{``{}}进行包裹。{``{}}在我理解,就是先用{}进行包裹,再用{}进行填充,例如:

python 复制代码
name = "golemon"
age = 21
greeting = "Hello, my name is {} and I am {} years old.".format({name}, age)

print(greeting)
# Hello, my name is {'golemon'} and I am 21 years old.
python 复制代码
sentence = "输出格式:{{'score': 0.5, 'label': 'negative'}},输入的文本是:{}"
sentence = sentence.format("我今天很开心")
print(sentence)
# 输出格式:{'score': 0.5, 'label': 'negative'},输入的文本是:我今天很开心

字符串调用 .format()有非常多的使用方法,可以自行搜索了解。

在提示词构建中,通常用的是{xxx},xxx表示用其他变量动态填充到xxx这里。

python 复制代码
sentence = "输出格式:{{'score': 0.5, 'label': 'negative'}},输入的文本是:{text}"
sentence = sentence.format(text="我今天很开心")
print(sentence)
# 输出格式:{'score': 0.5, 'label': 'negative'},输入的文本是:我今天很开心

还有format_map方法:

python 复制代码
sentence = "输出格式:{{'score': 0.5, 'label': 'negative'}},输入的文本是:{text1}, {text2}"
data = {
    "text1": "我今天很开心",
    "text2": "我今天很难过"
}
sentence = sentence.format_map(data)
print(sentence)
# 输出格式:{'score': 0.5, 'label': 'negative'},输入的文本是:我今天很开心, 我今天很难过

f-string也可以用来表示,但是对于提示词构建来说不如format好使,毕竟少个啥没有被动态填充难以直观看出来(

python 复制代码
text = "我今天很开心"
sentence = f"输出格式:{{'score': 0.5, 'label': 'negative'}},输入的文本是:{text}"
print(sentence)
# 输出格式:{'score': 0.5, 'label': 'negative'},输入的文本是:我今天很开心
相关推荐
奕辰杰25 分钟前
关于npm前端项目编译时栈溢出 Maximum call stack size exceeded的处理方案
前端·npm·node.js
t198751281 小时前
解决MySQL删除/var/lib/mysql下的所有文件后无法启动的问题
数据库·mysql·adb
JiaLin_Denny2 小时前
如何在NPM上发布自己的React组件(包)
前端·react.js·npm·npm包·npm发布组件·npm发布包
路光.3 小时前
触发事件,按钮loading状态,封装hooks
前端·typescript·vue3hooks
我爱996!3 小时前
SpringMVC——响应
java·服务器·前端
咔咔一顿操作4 小时前
Vue 3 入门教程7 - 状态管理工具 Pinia
前端·javascript·vue.js·vue3
天若有情6734 小时前
【python】Python爬虫入门教程:使用requests库
开发语言·爬虫·python·网络爬虫·request
kk爱闹4 小时前
用el-table实现的可编辑的动态表格组件
前端·vue.js
大佐不会说日语~4 小时前
Redis高频问题全解析
java·数据库·redis
IT北辰5 小时前
用Python+MySQL实战解锁企业财务数据分析
python·mysql·数据分析