本篇文章将分享如何使用 Ollama + DeepSeek + Dify 搭建本地知识库,让你轻松拥有一个专属的智能助手!
为什么要做这件事?在当前的环境下,AI所构建的专属知识库正重塑企业与个人的效能革命。对企业而言,它实现了经营数据的智能聚合与深度挖掘,将分散的日报、项目进展转化为实时分析看板,节省80%人工整理成本,同时揭示业务隐性规律,成为战略决策的”数字大脑”。对个人而言,这一系统如同智能助手,持续记录日报、项目心得与技能突破,自动提炼年度成果。无论是申请晋升的总结陈述,还是复盘成长路径,或是写一篇年终总结报告,知识库都能将零散记录转化为专业叙事,让努力“可视化”。在AI的赋能下,职场人终于能告别年终“突击写报告”的焦虑,实现真正的持续精进。
1. 工具介绍1.1 DeepSeek:低成本、高性能的 AI 模型DeepSeek 是一款由深度求索公司开发的高性能 AI 大模型,基于深度学习和多模态数据融合技术,采用了 Transformer 架构和跨模态协同算法。在极低成本下实现了与国际顶尖模型相媲美的性能表现,中文理解与输出能力更是超越了 ChatGPT 等顶尖模型。Dee ...
本文将对AI中的一些常见名词进行介绍,帮助大家对一些例如LLM、Agent、RAG、Prompt、Function Calling、MCP、本地部署之类的名词有个基本的认识。
1. LLM(大语言模型)1.1 什么是LLM?LLM(Large Language Model,大语言模型)是通过海量文本训练出的深度学习模型,能够理解、生成人类语言。如GPT、Claude、LLaMA、DeepSeek等。
1.2 LLM的核心技术
Transformer架构(2017年Google提出):采用自注意力机制(Self-Attention),让模型能并行处理长文本。
训练方式:
预训练(Pre-training):在万亿级token数据上训练(如Common Crawl、Wikipedia)。
微调(Fine-tuning):用指令数据优化模型行为(如ChatGPT的RLHF)。
1.3 不同的LLM对比
公司
代表模型
特点
开源情况
最大参数量
OpenAI
GPT-4、GPT-4o
闭源,商用API最强,支持多模态
仅API
~1.8T(估计)
Google
Gemin ...
引言作为一个游戏爱好者,我经常会出售一些游戏道具,一方面现在游戏道具出售流程已经很正规了,不用担心被骗。另一方面我也可以卖掉一些普通产出再去购买一些商城中的RMB道具来提升自己的账号。但是游戏内的产出很多时候需要花大量的时间和手动去获得,这是不可持续的。淘宝虽然有卖脚本、外挂的,弊端是很容易被扫描到非法进程,游戏更新后也经常会出现不能用的情况,最关键的问题是封号几率很大,属于低收益高风险行为。如果我能自己开发脚本,模拟人的操作行为,这个问题不就解决了?任他怎么更新,我直接跟上。
在过去的一年里,我尝试去做这件事,从最初的磕磕绊绊各种问题到如今可以轻松编写各种我需要的脚本,这段旅程充满了无数的学习、探索与成长。每一次的进步都让我充满成就感,也让我更加坚定了这条技术道路的探索与前行。
现在,我决定将这段经历整理成一系列教程,与大家分享我的知识和经验。无论你是编程新手,还是对游戏自动化感兴趣但不知从何入手,这个系列都将为你提供一个清晰的指引。
目录规划在这个教程系列中,我将涵盖以下内容:
基础篇:
Python环境搭建与基础语法回顾
游戏自动化原理与常用库介绍 (例如:pyautogu ...
Webpack
未读1. 什么是 Webpack?Webpack 是一个现代 JavaScript 应用程序的静态模块打包工具。它的核心功能是将项目中的各种资源(如 JavaScript、CSS、图片、字体等)视为模块,并通过依赖关系将它们打包成一个或多个静态资源文件。
简单来说,Webpack 的作用就是:
模块化:将复杂的代码拆分为模块,便于管理和维护。
打包:将所有模块及其依赖整合成一个或多个文件,减少 HTTP 请求,提升性能。
优化:通过插件(Plugin)和加载器(Loader)对代码进行压缩、转换、分割等操作,提升开发效率和项目性能。
2. 为什么需要 Webpack?在现代前端开发中,项目越来越复杂,代码量也越来越大。如果没有构建工具,我们会面临以下问题:
手动管理依赖:需要手动引入和管理各种库和资源,容易出错。
性能问题:过多的 HTTP 请求和未优化的代码会导致页面加载缓慢。
开发效率低:缺乏自动化工具,开发、调试和部署流程繁琐。
Webpack 的出现解决了这些问题:
自动化依赖管理:通过分析模块之间的依赖关系,自动打包所需资源。
代码优化:支持代码压缩、Tree Sha ...
Webpack
未读1. 环境准备在开始使用 Webpack 之前,我们需要确保本地环境已经安装了以下工具:
1.1 Node.js 和 npmWebpack 是基于 Node.js 的构建工具,因此需要先安装 Node.js 和 npm(Node.js 的包管理工具)。
下载并安装 Node.js:Node.js 官网
安装完成后,检查是否安装成功:
12node -v # 查看 Node.js 版本npm -v # 查看 npm 版本
1.2 初始化项目创建一个新的项目目录,并初始化 package.json 文件:
123mkdir webpack-demo # 创建项目目录cd webpack-demo # 进入项目目录npm init -y # 初始化 package.json
2. 安装 Webpack 和 Webpack CLIWebpack 将核心功能和命令行工具分离,因此需要分别安装 webpack 和 webpack-cli。
1npm install webpack webpack-cli --save-dev
安装完成后,检查是否安装成 ...
1. 入口(Entry)配置入口是 Webpack 开始构建依赖图的起点。Webpack 会从入口文件开始,递归地分析所有依赖的模块。
1.1 单入口配置最简单的配置方式是单入口,适用于小型项目或单页面应用(SPA)。
1234567module.exports = { entry: './src/index.js', // 单入口 output: { filename: 'bundle.js', path: __dirname + '/dist' }};
1.2 多入口配置对于多页面应用(MPA)或需要拆分包的场景,可以使用多入口配置。
12345678910module.exports = { entry: { app: './src/app.js', // 入口 1 admin: './src/admin.js' // 入口 2 }, output: { fi ...
1. 什么是 Loader?Loader用于对模块的源码进行转换。Webpack 默认只能处理 JavaScript 文件,但通过 Loader,我们可以处理其他类型的资源,例如 CSS、图片、字体等。
Loader 的特点:
链式调用:可以串联多个 Loader,按顺序对资源进行处理。
同步/异步:Loader 可以是同步的,也可以是异步的。
单一职责:每个 Loader 只专注于一种转换任务。
2. 常用 Loader 介绍以下是前端开发中常用的 Loader:
Loader 名称
作用
示例资源类型
babel-loader
将 ES6+ 代码转换为 ES5
JavaScript
css-loader
解析 CSS 文件
CSS
style-loader
将 CSS 注入到 HTML 中
CSS
file-loader
处理文件(如图片、字体)
图片、字体
url-loader
将小文件转换为 Base64 URL
图片、字体
sass-loader
将 SCSS/SASS 文件转换为 CSS
SCSS/SASS ...
1. 什么是 Plugin?Plugin 是 Webpack 的另一个核心功能,用于扩展 Webpack 的能力。与 Loader 不同,Plugin 的作用范围更广,可以干预打包的整个生命周期,从打包优化到资源管理,再到环境变量的注入等。
Plugin 的特点:
基于事件机制:Webpack 在打包过程中会触发一系列事件,Plugin 可以监听这些事件并执行相应的操作。
功能强大:Plugin 可以完成 Loader 无法实现的任务,例如生成 HTML 文件、压缩代码、提取 CSS 等。
配置灵活:Plugin 通常通过构造函数传入配置参数,支持高度定制。
2. 常用 Plugin 介绍以下是前端开发中常用的 Plugin:
Plugin 名称
作用
示例场景
HtmlWebpackPlugin
自动生成 HTML 文件
多页面应用
CleanWebpackPlugin
清理打包目录
每次打包前清理 dist
MiniCssExtractPlugin
将 CSS 提取为单独的文件
生产环境优化
OptimizeCSSAssetsPlugin
压缩 CSS ...
1. 为什么需要配置开发环境?在开发过程中,我们需要一些特定的工具和功能来提升开发效率,例如:
开发服务器:提供一个本地服务器,支持实时预览和自动刷新。
热更新(HMR):在不刷新页面的情况下更新模块。
Source Map:将打包后的代码映射回原始代码,便于调试。
快速构建:优化构建速度,减少开发等待时间。
Webpack 提供了丰富的配置选项来满足这些需求。
2. 配置开发服务器2.1 安装 webpack-dev-server首先,安装 webpack-dev-server:
1npm install webpack-dev-server --save-dev
2.2 配置开发服务器在 webpack.config.js 中配置开发服务器:
12345678module.exports = { devServer: { contentBase: './dist', // 服务器根目录 hot: true, // 启用热更新 port: 8080, // 端口号 open: true // 自动打开浏览器 ...
1. 为什么需要生产环境配置?在生产环境中,我们需要对代码进行优化,以提升项目的性能和用户体验。常见的优化手段包括:
代码压缩:减少文件体积,加快加载速度。
文件指纹:通过哈希值命名文件,避免缓存问题。
Tree Shaking:移除未使用的代码,减少打包体积。
代码分割:将代码拆分为多个文件,实现按需加载。
2. 配置生产环境模式Webpack 增加了 mode 选项,用于指定开发模式或生产模式。在生产模式下,Webpack 会自动启用一些优化功能。
2.1 配置生产模式在 webpack.config.js 中配置生产模式:
1234module.exports = { mode: 'production', // 生产模式 // 其他配置};
2.2 生产模式的默认优化
代码压缩:使用 TerserWebpackPlugin 压缩 JavaScript 代码。
Tree Shaking:自动移除未使用的代码。
Scope Hoisting:将模块合并到一个函数中,减少函数声明和内存开销。
3. 代码压缩3.1 压缩 Java ...