赞
踩
2022年11月30日,OpenAI发布ChatGPT 3
2022年12月4 日,ChatGPT 3 已拥有超过一百万用户
2023年各种大语言模型开始火爆全球
GPT们,已经成为了我工作和学习的非常重要的工具。
不知道大家有没有体验过OpenAI的ChatGPT,大家又是如何和ChatGPT对话的?有时候是不是也感觉他好像没那么神奇,有时候会答非所问,问题出在哪里?
试想一下,当我们去咖啡店里买咖啡,假设我们是在柜台和服务员面对面点咖啡。
我:你好,我要一杯咖啡
店员:您要什么口味的?
我:拿铁吧
店员:您是要中杯,大杯,还是超大杯?
我:我要超大杯。
店员:您是要无糖,半糖,还是全糖?
我:半糖。
店员:您是要热的,去冰的,还是少冰的?
我:热的。
店员:好的,您稍等,马上为您制作。
我们在日常生活中,正常的人与人的沟通尚且如此,需要一步一步,循序渐进,最终才能达成一致,得到想要的结果,更何况我们与一个AI助手聊天?
也就是相处多年的朋友在简单说了几句话后,说出一句:你懂的,然后大家都明白是什么了。如果换作是一位不那么熟悉的朋友,丢出一句:你懂的,如果你们聊天的内容不是大家都熟悉的,如果大家不在一个语境之中,我相信,你肯定不懂。更何况一个AI助手。
所以当我们与AI助手聊天时,不要期待一句话就想得到你想要的结果。有时候AI助手返回的结果不是我们想要的,通常都是因为我们表述得不够清楚。AI助手无法根据我们的提示,猜测我们真正想要表达的是什么。
所谓指令,就是我们给ChatGPT的输入,专业术语叫:Prompt,指令工程就是Prompt Engineering. ChatGPT会根据我们的输入,生成相应的输出。
Prompt的质量直接影响ChatGPT输出的质量。而指令工程,就是对Prompt进行调优,使ChatGPT返回符合我们预期结果的过程。
提示:告诉GPT是一个什么角色,我们希望他做些什么
上下文:与任务有关的具体的描述
例子:告诉GPT一些加深他理解问题的例子
输入:提供一些与任务相关的输入信息
输出:告诉GPT输出的格式是怎样的
下面是一个比较详细的例子,大家复制下面的内容,将注释去掉,粘贴至ChatGPT的对话框,看看会输出怎样的结果。
#告诉GPT是什么角色,希望他帮助我们干什么? 你好,你是一位资深EXCEL用户,你非常善于使用编写VBA脚本来完成使用EXCEL来处理各种数据。 #提供一些关于任务的重要信息 我现在有一个sheet, sheet名称是:system_info, 我希望你写一段VBA程序,要求遍历整张表,计算出每一列的长度,并将结果写入名称为 column_length的sheet中 #说明怎么求列的列度,以及从哪里开始 请注意, 1. 列名为第1行,数据从第2行开始 2. 列的长度是该列中所有记录中最长的那条记录的长度值 #指定数据输出的格式 结果的输出格式为: 1. 第一行为列名 2. 第二行为每一列的长度 3. 第三行为每列最长的那一行的行号
以下是GPT的输出
Sub CalculateColumnLength() Dim wsData As Worksheet Dim wsResult As Worksheet Dim lastRow As Long Dim lastCol As Long Dim i As Long, j As Long Dim maxLength() As Long Dim maxRow() As Long ' 获取数据所在的sheet Set wsData = ThisWorkbook.Sheets("system_info") ' 创建结果存储的sheet Set wsResult = ThisWorkbook.Sheets.Add(After:=Sheets(Sheets.Count)) wsResult.Name = "column_length" ' 获取数据范围 lastRow = wsData.Cells(wsData.Rows.Count, 1).End(xlUp).Row lastCol = wsData.Cells(1, wsData.Columns.Count).End(xlToLeft).Column ' 初始化数组 ReDim maxLength(1 To lastCol) ReDim maxRow(1 To lastCol) ' 遍历每一列,计算长度和最长行号 For j = 1 To lastCol maxLength(j) = 0 maxRow(j) = 0 For i = 2 To lastRow If Len(wsData.Cells(i, j).Value) > maxLength(j) Then maxLength(j) = Len(wsData.Cells(i, j).Value) maxRow(j) = i End If Next i Next j ' 将结果写入结果sheet For j = 1 To lastCol wsResult.Cells(1, j).Value = wsData.Cells(1, j).Value ' 列名 wsResult.Cells(2, j).Value = maxLength(j) ' 列长度 wsResult.Cells(3, j).Value = maxRow(j) ' 最长行号 Next j ' 调整列宽 wsResult.Columns.AutoFit MsgBox "计算完成,结果已写入 column_length sheet。" End Sub
通过上面的例子,我们就已经基本了解了如何去编写一个好用的提示词,让ChatGPT来帮助实现想要的结果。
实际上,编辑提示词,就好你我们编辑代码一样,也是需要经过一轮一轮的迭代,不断的调整,不断的增加新的逻辑,最终才能让ChatGPT输出满足我们需求的结果。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。