AIGC时代之 - 怎样更好的利用AI助手 - 指令工程

发布于:2024-04-30 ⋅ 阅读:(24) ⋅ 点赞:(0)

爆火的AIGC

2022年11月30日,OpenAI发布ChatGPT 3
2022年12月4 日,ChatGPT 3 已拥有超过一百万用户
2023年各种大语言模型开始火爆全球

GPT们,已经成为了我工作和学习的非常重要的工具。

ChatGPT也没那么神奇?

不知道大家有没有体验过OpenAI的ChatGPT,大家又是如何和ChatGPT对话的?有时候是不是也感觉他好像没那么神奇,有时候会答非所问,问题出在哪里?
答非所问

人与人是怎么沟通的

试想一下,当我们去咖啡店里买咖啡,假设我们是在柜台和服务员面对面点咖啡。
我:你好,我要一杯咖啡
店员:您要什么口味的?
我:拿铁吧
店员:您是要中杯,大杯,还是超大杯?
我:我要超大杯。
店员:您是要无糖,半糖,还是全糖?
我:半糖。
店员:您是要热的,去冰的,还是少冰的?
我:热的。
店员:好的,您稍等,马上为您制作。

我们在日常生活中,正常的人与人的沟通尚且如此,需要一步一步,循序渐进,最终才能达成一致,得到想要的结果,更何况我们与一个AI助手聊天?

也就是相处多年的朋友在简单说了几句话后,说出一句:你懂的,然后大家都明白是什么了。如果换作是一位不那么熟悉的朋友,丢出一句:你懂的,如果你们聊天的内容不是大家都熟悉的,如果大家不在一个语境之中,我相信,你肯定不懂。更何况一个AI助手。

所以当我们与AI助手聊天时,不要期待一句话就想得到你想要的结果。有时候AI助手返回的结果不是我们想要的,通常都是因为我们表述得不够清楚。AI助手无法根据我们的提示,猜测我们真正想要表达的是什么。

怎么样和AI助手聊天

  • 不要期待一句话就想得到你想要的结果
  • 别以为你已经讲清楚了,AI可能还没完全理解
  • 说得越多越好,提供越多的信息,可以帮助AI理解你的需求

什么是指令工程

所谓指令,就是我们给ChatGPT的输入,专业术语叫:Prompt,指令工程就是Prompt Engineering. ChatGPT会根据我们的输入,生成相应的输出。

Prompt的质量直接影响ChatGPT输出的质量。而指令工程,就是对Prompt进行调优,使ChatGPT返回符合我们预期结果的过程。

Prompt 的基本构成

提示:告诉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输出满足我们需求的结果。


网站公告

今日签到

点亮在社区的每一天
去签到