ChatGPT工作提效之小鹅通二次开发批量API对接解决方案(学习记录同步、用户注册同步、权益订购同步、开发文档)

这篇具有很好参考价值的文章主要介绍了ChatGPT工作提效之小鹅通二次开发批量API对接解决方案(学习记录同步、用户注册同步、权益订购同步、开发文档)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

ChatGPT工作提效系列

  1. ChatGPT工作提效之初探路径独孤九剑遇强则强
  2. ChatGPT工作提效之在程序开发中的巧劲和指令(创建MySQL语句、PHP语句、Javascript用法、python的交互)
  3. ChatGPT工作提效之生成开发需求和报价单并转为Excel格式

ChatGPT是一种实时对话生成模型,能够帮助用户快速地回答问题、提供信息,并且能够流畅地进行对话,准确理解用户的意图,并作出相应的回应。

ChatGPT模型的优点在于其生成文本的自然度和连贯度都非常好,不会出现明显的逻辑错误和语法错误。此外,ChatGPT的训练数据集丰富多样,能够应对大部分的问题场景。由于使用预训练模型,可以快速定制成各种应用场景的问答模型,能够大幅提升开发效率。不过,ChatGPT也存在一些缺点。由于其是基于预训练模型的生成模型,无法像传统的规则引擎一样对自己的回答逻辑处理进行调整,因此产生了一些无意义的回答或者矛盾的回答。

近期,在小鹅通的项目实战开发过程中,增加了“面向ChatGPT开发”的使用频率。现就有关过程记录如下:

ChatGPT工作提效之小鹅通二次开发批量API对接解决方案(学习记录同步、用户注册同步、权益订购同步、开发文档)

一、项目需求

调用小鹅通API接口获取指定资源学习记录信息,xe.user.leaning_record_by_resource.get/1.0.0。
请求方式及url

  • 请求方式:POST
  • 请求头:Content-Type:application/json
  • 接口地址:https://api.xiaoe-tech.com/xe.user.leaning_record_by_resource.get/1.0.0
  • 频率限制:10秒3000次
  • 备注:数据是准实时的,4~5分钟延迟
  • user_id数组,请求数量上限,请求参数如图:
    ChatGPT工作提效之小鹅通二次开发批量API对接解决方案(学习记录同步、用户注册同步、权益订购同步、开发文档)
    目前需要在小鹅通上述API条件的限制做,批量获取用户指定资源的学习记录。在php中是完善的延迟进程的算法的,很容易API超限或请求频繁导致token失效。
    如何实现队列更新呢?

1.chatGPT:使用php分批分时输出的代码

php写一下一个100长度的数组,分批分时输出的代码

<?php

// 创建一个100长度的数组
$array = range(1, 100);

// 每批输出的长度
$batch_size = 10;

// 循环输出数组内容
for ($i = 0; $i < count($array); $i += $batch_size) {
    echo "批次 " . ($i / $batch_size + 1) . "\n";
    echo implode(", ", array_slice($array, $i, $batch_size)) . "\n";
    sleep(1); // 暂停1秒,以模拟分时输出
}

?>

sleep(1)

2.chatGPT使用javascript分批分时输出的代码

在javascript中实现一个100长度的数组,分批分时输出的代码怎么写

 var arr = Array(100).fill(null).map((_, i) => i + 1); // 创建长度为100的数组

    function outputArrayInBatch(arr, batchNum, interval) {
        var startIndex = batchNum * interval; // 当前批次的起始索引
        var endIndex = (batchNum + 1) * interval; // 当前批次的结束索引
        if (startIndex > arr.length - 1) {
            return; // 当所有元素都输出完毕后,退出递归
        }
        if (endIndex > arr.length) {
            endIndex = arr.length; // 当结束索引超过数组长度时,将结束索引设置为数组的最后一个元素的索引
        }
        var batchArr = arr.slice(startIndex, endIndex); // 当前批次需要输出的元素数组
     
        //对批次数组进行遍历操作;
        console.log(batchArr); // 输出当前批次的元素
        
        setTimeout(function () {
            outputArrayInBatch(arr, batchNum + 1, interval); // 递归调用下一批次的输出
        }, 2000); // 每隔1秒输出一批次
    }

    // 执行输出
    outputArrayInBatch(arr, 0, 10); // 一次输出10个元素,共分10批输出

代码中首先创建了长度为100的数组。outputArrayInBatch()函数接收三个参数:待输出的数组、当前批次数、每批次需要输出的元素个数。在函数中,首先根据批次数和输出元素个数计算当前需要输出的元素数组;然后输出当前批次的元素,并通过setTimeout()函数递归调用函数,输出下一批次的元素。

这里输出的是每隔1秒输出一批次的元素,可以根据具体需求调整输出时间间隔。
ChatGPT工作提效之小鹅通二次开发批量API对接解决方案(学习记录同步、用户注册同步、权益订购同步、开发文档)

二、批量修复API接口

1.修复单位不存在API

public function upDepart()
    {
        global $db, $res;
        dbc();
        @$user_phone = get_param('user_phone');
        if ($user_phone == "") {
            die("参数错误");
        }
        //读取单位认证
        $row = $db->fetch('depart_audit', '*', array('user_phone' => $user_phone), ' audit_id DESC');

        //获取单位ID
        $row_depart = $db->fetch('depart', 'depart_id', array('depart_name' => $row['depart_name']), ' depart_id DESC');
        if ($row_depart['depart_id'] == "") {
            die("单位不存在或未验证");
        }

        //更新单位库
        $user_roles = 1;//单位管理员权限;
        $user_menu = 0;//可操作
        $user_auth = 1;//已审
        $db->insert('admin', array('user_phone' => $user_phone, 'user_name' => $row['user_name'], 'user_pwd' => $row['user_pwd'], 'user_mail' => $row['user_mail'], 'depart_id' => $row_depart['depart_id'], 'user_depart' => $row['depart_name'],
            'user_branch' => $row['user_branch'], 'user_titles' => $row['user_titles'], 'user_province' => $row['province'], 'user_city' => $row['city'], 'user_area' => $row['area'],
            'user_roles' => $user_roles, 'user_menu' => $user_menu, 'user_auth' => $user_auth));

        $res["data"] = $user_phone . "-更新成功";
        die(json_encode_lockdata($res));
    }

2.修复单位depart_id不存在

public function upDeID()
    {
        global $db, $res;
        dbc();
        //读取管理员信息
        $sql = "select depart_id,user_depart FROM " . $db->table('admin') . " WHERE depart_id IS NULL";
        $sql .= " ORDER BY user_id DESC";
        $row = $db->queryall($sql);
        for ($i = 0; $i < count($row); $i++) {
            // echo $row[$i]['user_depart'] . '<br>';
            //获取单位ID
            $row_depart = $db->fetch('depart', 'depart_id,depart_name', array('depart_name' => $row[$i]['user_depart']), ' depart_id DESC');
            if ($row_depart) {
                $db->update('admin', array('depart_id' => $row_depart['depart_id']), array('user_depart' => $row[$i]['user_depart']));
            }
        }

        $res["data"] = "更新成功";
        die(json_encode_lockdata($res));
    }

3.批量更新登录权限

public function upAuth()
    {
        global $db, $res;
        dbc();
        $db->update('user', array('user_auth' => 1), array('user_auth' => 0));
        $res["data"] = "更新成功";
        die(json_encode_lockdata($res));
    }

三、开发中遇见的问题

1.查询字段为空的sql语句

mysql筛选某字段未空的查询语句怎么写

在MySQL中,筛选某字段未空的查询语句可以使用 IS NOT NULL 来表示。例如,假设有一个表名为 my_table,其中包含 field1 字段,要查找 field1 字段不为空的数据,可以使用以下 SQL 查询语句:

SELECT * FROM my_table WHERE field1 IS NOT NULL;

其中 SELECT * 表示选择所有列,FROM my_table 表示从 my_table 表中查询数据,WHERE field1 IS NOT NULL 表示筛选 field1 字段不为空的数据。

如果要筛选出某个字段值为空的数据,可以使用 IS NULL 来表示,例如:

SELECT * FROM my_table WHERE field1 IS NULL;

这条 SQL 查询语句将会返回 field1 字段为空的记录所有数据,其他字段可能为空或者有值。

而在实际的开发过程中,在写查询字段为空的sql语句中时,用了is null查表中user_eid为空的记录,结果是没有结果。其原因在于,只有是显示(null)的字段才是真正的空值,如果之前为该字段赋值之后删除值框里什么都没有应该是下面的写法:user_eid = ''

    public function getEid()
    {
        checkAdminAuth($_COOKIE['admin_roles'], '0', 1);//超管权限
        global $db, $res;
        dbc();
        //读取管理员信息
        $sql = "select user_eid,user_name,user_phone FROM " . $db->table('user') . " WHERE user_eid = ''";
        $sql .= " ORDER BY user_id DESC";// LIMIT 100
        $row = $db->queryall($sql);
        $res["data"] = $row;
        die(json_encode_lockdata($res));
    }

2.设置登录cookie永不过期

php如何设置登录cookie永不过期

要设置PHP登录cookie永不过期,可以指定一个很大的过期时间,如设置为2038年1月19日,这是PHP可以处理的最大日期。

可以使用setcookie()函数设置cookie,具体示例如下:

$cookie_name = "user";
$cookie_value = "John Doe";
$expiry_date = strtotime('2038-01-19');
setcookie($cookie_name, $cookie_value, $expiry_date, "/");

在上面的示例中,$expiry_date变量设置为2038年1月19日的时间戳,该时间戳将在setcookie()函数中设置为cookie的过期时间。在本例中,cookie的路径设置为“/”,这表示cookie与服务器上所有页面都关联,而不是仅与当前页面关联。

这样设置后,用户的登录cookie将被永久保存,直到浏览器将其删除或达到在服务器上规定的最长持续时间为止。

3.实现短信验证码的代码是什么

除了Redis外,还有很多其他的方式实现短信验证码的流控。下面是一个基于文件系统的示例代码:

<?php

// 定义短信验证码保存目录
define('SMS_DIR', '/path/to/sms/dir/');

// 获取客户端IP地址
$ip = $_SERVER['REMOTE_ADDR'];

// 获取手机号码
$phone = 'your_phone_number';

// 定义文件名规则
$filename = md5($ip . $phone) . '.json';

// 检查文件是否存在
if (file_exists(SMS_DIR . $filename)) {
    // 如果文件存在,则读取文件内容
    $content = file_get_contents(SMS_DIR . $filename);

    // 解析JSON内容
    $data = json_decode($content, true);

    // 如果超过发送次数限制,则提示用户并退出
    if ($data['count'] >= 5 && time() - $data['timestamp'] < 300) {
        echo "发送频率过快,请稍后再试。";
        exit;
    } else {
        // 如果可以发送,则将发送次数加1,并更新时间戳
        $data['count']++;
        $data['timestamp'] = time();
    }
} else {
    // 如果文件不存在,则创建新文件并写入初始内容
    $data = [
        'count' => 1,
        'timestamp' => time()
    ];

    $content = json_encode($data);

    file_put_contents(SMS_DIR . $filename, $content);
}

// 发送短信验证码

?>

在上述代码中,将短信验证码的发送次数保存在一个JSON文件中,与客户端IP地址和手机号码相关联。代码中使用md5值来生成文件名,文件内容为JSON格式的字符串,包含发送次数和最后发送时间戳两个字段。

在发送短信验证码时,先根据请求参数生成文件名,然后检查是否存在对应的文件。如果文件存在,则读取文件内容,检查发送次数和时间戳是否超过限制。如果可以发送,则将发送次数加1,并将更新后的内容写回文件;如果发送次数已经达到限制,则提示用户稍后再试。如果文件不存在,则创建新文件,并写入初始的发送次数和时间戳。

基于文件系统的方式性能略低于Redis或其他内存型数据库,同时也更容易受到并发访问的影响。因此,建议在高并发场景下使用更为高效的Redis等缓存服务器。


@漏刻有时文章来源地址https://www.toymoban.com/news/detail-462815.html

到了这里,关于ChatGPT工作提效之小鹅通二次开发批量API对接解决方案(学习记录同步、用户注册同步、权益订购同步、开发文档)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • AIGC: 关于ChatGPT中API接口调用相关准备工作

    ChatGPT之API接口相关 通过页面和GPT交流获取信息相比直接调用GPT的API而言是非常有限的 页面上的GPT是比较封闭的,而且只允许我们去输入文本的信息 我们需要借助GPT的API开发来激发AI工具的无限可能,实现更多个性化需求 1 ) 使用API 使用API有一个前置的条件 注册ChatGPT账号

    2024年02月04日
    浏览(38)
  • 让AI帮你工作(3)--学习提效

    今天会给大家带来两款对学习工作提效的两款chatgpt相关的工具,同时会给围绕chatgpt做产品的同学带来一个开发框架。 背景: 在工作和学习中我们有很多时间是在和视频、网页打交道。在youtube上看国外著名大学的学习课程、看看歪果仁他们在玩什么新东西,或者是用网页搜

    2024年02月09日
    浏览(30)
  • HBase Java API 开发:批量操作 第2关:批量删除数据

    删除单行数据 删除一行数据很简单,我们来看个示例: 这段代码就可以删除行键为 row1 的行。 删除多行数据 如何删除多行数据呢? 相信你已经猜到了,既然 get() 方法有重载方法,那应该 delete() 方法也有,确实: 这样就可以删除多行数据啦。 编程要求 还等啥,亲自试一试

    2024年02月05日
    浏览(45)
  • 软件工程:左移策略,决策和工作要前置,是提效的关键

    hi,我是熵减,见字如面。 在软件开发的中,你是否也遇到过类似的场景: 团队的目标是在1个月内,开发出一款新的社交媒体应用程序。由于时间比较紧,任务重,所以在开发的初期,方案设计、质量保障和安全性等上面,都是未能充分的考虑,以此来节省开发成本,并保

    2023年04月25日
    浏览(36)
  • HBase Java API 开发:表的扫描与扫描的缓存和批量处理 第1关:批量处理

    批量操作 如果我们去查看 HBaseAPI 的源码会发现,在上次实训中我们使用的 delete、get,put 这些批量操作,实际上都是调用了 batch() 方法。 查看 put(ListPut puts) 函数源码: 我们可以发现 put(ListPut puts) 方法最终还是调用的 batch(final List? extends Row actions, final Object[] results, int rpcTi

    2024年02月09日
    浏览(31)
  • “提效”|教你用ChatGPT玩数据

    上文给简单聊了一下为什么ChatGPT不能取代数据分析师,本文我们来深入感受一下如何让GPT帮助数据分析师“提效”。 场景一:SQL取数 背景:多数数据分析师都要用SQL语言从数据库中提取数据,SQL虽然简单,但是写几百行取数代码也是很头疼的一个操作,这个时候不妨交给

    2023年04月22日
    浏览(33)
  • 10倍提效!用ChatGPT编写系统功能文档。。。

    系统功能文档是一种描述软件系统功能和操作方式的文档。它让开发团队、测试人员、项目管理者、客户和最终用户对系统行为有清晰、全面的了解。 通过ChatGPT,我们能让编写系统功能文档的效率提升10倍以上。 ​《Leetcode算法刷题宝典》一位阿里P8大佬总结的刷题笔记。

    2024年04月09日
    浏览(30)
  • chatgpt智能提效职场办公-ppt怎么蒙层

    作者:虚坏叔叔 博客:https://xuhss.com 早餐店不会开到晚上,想吃的人早就来了!😄 在 PowerPoint 中添加蒙版图层,可以在幻灯片中创建一个半透明的矩形或形状,并在其上方添加或放置其他对象。 下面是一些步骤: 在幻灯片中,添加一个形状或图像,并将其放在你想要添加

    2023年04月26日
    浏览(35)
  • chatgpt智能提效职场办公-ppt怎么全屏

    作者:虚坏叔叔 博客:https://xuhss.com 早餐店不会开到晚上,想吃的人早就来了!😄 在PowerPoint中,可以通过以下几种方法将演示文稿切换到全屏模式: 方法1:按F5键 在编辑演示文稿的状态下,按下键盘上的F5键即可将演示文稿全屏显示。 方法2:在菜单栏中点击“幻灯片放映

    2024年02月07日
    浏览(37)
  • AI+软件工程:10倍提效!用ChatGPT编写系统功能文档

    系统功能文档是一种描述软件系统功能和操作方式的文档。它让开发团队、测试人员、项目管理者、客户和最终用户对系统行为有清晰、全面的了解。 通过ChatGPT,我们能让编写系统功能文档的效率提升10倍以上。 我们以线上商城系统为例,介绍如何使用ChatGPT帮我们完成系统

    2024年03月25日
    浏览(50)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包