Linux之日志
日志
在编写网络服务器, 各种软件时, 程序一定要打印一些日志信息.
1. 可以向显示器打印, 也可以向文件中写入.
2. 日志是软件在运行时记录的流水账, 用于排查服务进程挂掉的信息.
- 其中必须要有的是: 日志等级, 时间, 日志内容.
- 可选的是文件名, 代码行数, 进程pid 等
日志等级可以根据需要设置, 暂时先设置5个:
enum LogLevel
{Debug = 0,Info,Warning,Error,Fatal
};
我们的日志输出方式可以分为3类: 显示器打印, 不分类写入一个文件, 根据日志等级分类写入不同文件
enum OutPutStyle
{SCREEN = 0,//显示器打印ONEFILE,//输入到一个文件CLASSFILES//分类输出
};
我们可以设置:
- 默认的输出方式是SCREEN
- 默认的日志文件目录名称为log
- 默认日志文件名为log.xxx, 后缀后面再详细设置
可以利用mkdir接口创建目录:
const OutPutStyle defaultStyle = SCREEN;
const std::string defaultFileName = "log.";
const std::string defaultDirName = "log";class Log
{
public:Log(OutPutStyle style = defaultStyle): _style(style){if(style != SCREEN)mkdir(defaultDirName.c_str(), 0777);}
private:OutPutStyle _style;
};
然后我们要完成日志的主体工作:
void LogMessage(LogLevel level, const char *format, ...){char headBuffer[1024] = {0};sprintf(headBuffer, "[%s][%s][%d]: ", LevelToString(level).c_str(), TimeToString().c_str(), getpid());char contentBuffer[1024] = {0};va_list arg;va_start(arg, format);vsprintf(contentBuffer, format, arg);va_end(arg);std::string message = std::string(headBuffer) + std::string(contentBuffer);switch (_style){case SCREEN:WriteToScreen(message);break;case ONEFILE:WriteToFile("all", message);break;case CLASSFILES:WriteToClassFILE(LevelToString(level), message);break;default:std::cout << "Unknown Style" <<std::endl;break;}}
LogMessage函数就是为了将日志的内容根据日志的 style 输出.
一. 由于我们并不确定每次要向日志输出的内容, 所以用一个可变参数列表来模仿 printf 形式的输出格式:
1. 首先headBuffer是我们必带的属性: 日志等级, 时间, 和进程的pid;
2. 然后利用通过可变参数相关的宏和vsprintf把内容输出到contenBuffer中, 用法类似sprintf, 只是最后一个参数的变化.
3. 然后就得到了我们所需的完整的message.
关于vsprintf的接口:
二. 接着根据需要的输出风格把日志内容输出即可, 这里我们封装三个函数, 分别是WriteToScreen, WriteToFile, WriteToClassFILE:
void WriteToScreen(const std::string& message)
{std::cout << message << std::endl;
}void WriteToFile(const std::string& levelstr, const std::string& message)
{std::string filename = defaultDirName + "/" + defaultFileName + levelstr;std::ofstream os(filename.c_str(), std::ofstream::out | std::ofstream::app);if(!os.is_open()){std::cout << "open error" << std::endl;exit(1);}os << message << std::endl;os.close();
}void WriteToClassFILE(const std::string& levelstr, const std::string& message)
{WriteToFile(levelstr, message);
}
1. 输出到屏幕直接输出即可.
2. 输出到文件需要通过日志等级确定文件的后缀名, 所以多加一个参数.
三. 记得添加需要的两个功能函数, 将日志等级转换为字符串和获取时间
std::string LevelToString(LogLevel level){switch (level){case Debug:return "Debug";break;case Info:return "Info";break;case Warning:return "Warning";break;case Error:return "Error";break;case Fatal:return "Fatal";break;default:return "Unknown";break;}}std::string TimeToString(){time_t time = std::time(nullptr);char timeString[] = "yyyy-mm-ddThh:mm:ssZ";//std::cout << typeid(std::data(timeString)).name() << std::endl;std::strftime(timeString, sizeof(timeString), "%F %T", std::localtime(&time));return timeString;}
这样日志就设计完成. 测试一下, 这里我们选择分类输出:
#include "log.hpp"int main()
{Log lg(CLASSFILES);lg.LogMessage(Debug, "this is a log message %d %s", 42, "hello world");lg.LogMessage(Info, "this is a log message %d %s", 42, "hello world");lg.LogMessage(Warning, "this is a log message %d %s", 42, "hello world");lg.LogMessage(Error, "this is a log message %d %s", 42, "hello world");lg.LogMessage(Fatal, "this is a log message %d %s", 42, "hello world");return 0;
}
运行之后目录下多出一个log文件夹, 里面记录了不同日记等级的日志
查看一下内容:
补充:
logMessage部分我们也可以用C++11的可变参数列表来实现:
template<class T>void BuildContent(std::ostringstream& oss, T head) {oss << head;}template<class T, class ...Args>void BuildContent(std::ostringstream& oss, T head, Args... rest) {oss << head << " "; // 每个参数用空格分隔BuildContent(oss, rest...);}template<class T, class ...Args>void LogMessage(LogLevel level, T head, Args... rest){char headBuffer[1024] = {0};sprintf(headBuffer, "[%s][%s][%d]: ", LevelToString(level).c_str(), TimeToString().c_str(), getpid());std::ostringstream oss;BuildContent(oss, head, rest...); std::string contentBuffer = oss.str();std::string message = std::string(headBuffer) + contentBuffer;switch (_style){case SCREEN:WriteToScreen(message);break;case ONEFILE:WriteToFile("all", message);break;case CLASSFILES:WriteToClassFILE(LevelToString(level), message);break;default:std::cout << "Unknown Style" <<std::endl;break;}}
不过这样我们在使用logMessage函数时就要注意一下格式, 我们使用了ostringstream, 所以使用的方式类似于流输出的形式, 此外我们还默认给每个参数之间添加了空格分隔.
int main()
{Log lg(CLASSFILES);lg.LogMessage(Debug, "this is a log message", 42, "hello world");lg.LogMessage(Info, "this is a log message", 42, "hello world");lg.LogMessage(Warning, "this is a log messag", 42, "hello world");lg.LogMessage(Error, "this is a log message", 42, "hello world");lg.LogMessage(Fatal, "this is a log message", 42, "hello world");return 0;
}
输出结果和之前是一样的.
关于可变参数列表
这是关于C语言的可变参数列表的介绍, 可以选择性观看.
引例
求两个数最大值
int FindMax(int x,int y) { if(x>y){ return x; } return y; }
首先明确三个问题
1.如果函数没有形式参数, 我们也可以给函数传递参数
2.在C中, 只要发生了函数调用并且传递了参数, 必定形成临时变量
3.所谓的临时拷贝本质就是在当前函数栈帧内部形成的数据, 且顺序是从右到左依次形成临时拷贝.
现在我们想要: 求任意多个数据中的最大值(至少一个), 且要求不能使用数组.
因为目前参数个数不确定,那么函数编写的时候, 参数个数也无法确定, 换句话说, 函数也就没法编写, 不过, C提供了满足该场景的解决方案: 可变参数列表
先了解如何使用可变参数列表:
int FindMax(int num,...)//使用可变参数的要求,至少使用一个明确的参数
{va_list arg;//定义可以访问可变参数部分的变量,其实是一个char*类型va_start(arg,num); //使arg指向可变参数部分int max = va_arg(arg,int);//根据类型,获取可变参数列表中的第一个数据for(int i =0;i<num;i++)//获取并比较其他的{int cur = va_arg(arg,int);if(max<cur){max = cur; } }va_end(arg); //arg使用完毕,收尾工作。本质就是讲arg指向NULLreturn max;
}
int main()
{int max = FindMax(5,11,22,33,44,55);printf("max = %d\n", max);return 0;
}
如果将参数改成char类型,求char类型变量中的最大值,代码会有问题吗?
int FindMax(int num, ...)
{va_list arg; //char*va_start(arg, num); int max = va_arg(arg, int);//va_arg(arg,char);是不正确的for (int i = 0; i < num - 1; i++){//获取并比较其他的int curr = va_arg(arg, int);if (max < curr){max = curr;}}va_end(arg); //arg使用完毕,收尾工作。本质就是讲arg指向NULLreturn max;
}
int main()
{char a = '1'; //ascii值: 49char b = '2'; //ascii值: 50char c = '3'; //ascii值: 51char d = '4'; //ascii值: 52char e = '5'; //ascii值: 53int max = FindMax(5, a, b, c, d, e);printf("max = %d\n", max);return 0;
}
//结果并未受影响,可是,我们解析的时候,是按照va_arg(arg, int)来解析的,这是为什么?
通过查看汇编,我们看到,在可变参数场景下:
实际传入的参数如果是char, short, float, 编译器在编译的时候, 会自动进行提升(通过查看汇编,我们都能看到), movsx 把值进行带符号扩展
函数内部使用的时候,根据类型提取数据,一般是通过int或者double来进行
注意事项
1. 可变参数必须从头到尾逐个访问。如果你在访问了几个可变参数之后想半途终止,这是可以的,但是,如果你想一开始就访问参数列表中间的参数,那是不行的。
2. 参数列表中至少有一个命名参数. 如果连一个命名参数都没有, 就无法使用 va_start, 因为根本找不到可变参数的起始位置.
3. 这些宏是无法直接判断实际存在参数的数量。//printf在第一个参数的格式化字符串中的%可以判定有几个参数
4. 这些宏无法判断每个参数的类型。
5. 如果在 va_arg 中指定了错误的类型,那么其后果是不可预测的。
可变参数的原理:
可变参数列表对应的函数, 最终调用也是函数调用, 也要形成栈帧. 栈帧形成前, 临时变量是要先入栈的, 我们知道参数之间位置关系是相对固定的
通过上面汇编的查看,发现了短整型在可变参数部分,会默认进行整形提升,那么函数内部在提取该数据的时候,就要考虑提升之后的值,如果不加考虑,获取数据可能会报错或者结果不正确.
几个宏的含义:
1. va_list;
va_list其实就是char*类型,方便后续按照字节进行指针移动
2. va_start, va_arg , va_end
3. 核心工作是三个宏的定义
#define _crt_va_start(ap, v) ( ap = (va_list)_ADDRESSOF(v) + _INTSIZEOF(v) )
举例:arg = (char*)&num + 4
#define _crt_va_arg(ap, t) ( *(t *)((ap += _INTSIZEOF(t)) - _INTSIZEOF(t)) )
1. 把“当前元素”提取出来
2. arg指向下一个待访问元素
#define _crt_va_end(ap) ( ap = (va_list)0 )
指针归零,防止野指针
其中: #define _ADDRESSOF(v) ( &(v) ) 是取参数的地址, 很好理解
关键是对于偏移量的计算, 如何正确拿到下一个参数的大小?
#define _INTSIZEOF(n) ( (sizeof(n) + sizeof(int) - 1) & ~(sizeof(int) - 1) ) //难点!!
_INTSIZEOF(n)的意思:计算一个最小数字x,满足 x>=n && x%4==0,其实就是一种4字节对齐的方式:
比如n是:1,2,3,4 对n进行向 sizeof(int) 的最小整数倍取整的问题 就是 4
比如n是:5,6,7,8 对n进行向 sizeof(int) 的最小整数倍取整的问题 就是 8
第一步理解:4的倍数
既然是4的最小整数倍取整,那么本质是:x=4*m,m是具体几倍。对7来讲,m就是2,对齐的结果就是8 而m具体是多少,取决于n是多少
如果n能整除4,那么m就是n/4
如果n不能整除4,那么m就是n/4+1
上面是两种情况,如何合并成为一种写法呢?
常见做法是 ( n+sizeof(int)-1) )/sizeof(int) -> (n+4-1)/4
如果n能整除4,那么m就是(n+4-1)/4->(n+3)/4, +3的值无意义,会因取整自动消除,等价于 n/4.
如果n不能整除4,那么n=最大能整除4部分+r,1(能整除4部分+r+3)/4,其中4 能整除4部分/4 + (r+3)/4 -> n/4+1
第二步理解:最小4字节对齐数
搞清楚了满足条件最小是几倍问题,那么,计算一个最小数字x,满足 x>=n && x%4==0,就变成了
((n+sizeof(int)-1)/sizeof(int))[最小几倍] * sizeof(int)[单位大小] -> ((n+4-1)/4)*4
这样就能求出来4字节对齐的数据了,其实上面的写法,在功能上,已经和源代码中的宏等价了。
第三步理解:理解源代码中的宏
拿出简洁写法:((n+4-1)/4)* 4,设w=n+4-1, 那么表达式可以变化成为 (w/4)*4, 而4就是2^2,w/4,不就相当于右移两位吗? 再除4不就相当左移两位吗?先右移两位,在左移两位,最终结果就是, 最后2个比特位被清空为0!
所以(w/4)*4等价于w & ~3
所以, 简洁版:(n+4-1) & ~(4-1)
所以最终得到了源码版的_INTSIZEOF(n): ( (sizeof(n) + sizeof(int) - 1) & ~(sizeof(int) - 1 ) ) 无需先/,再*
相关文章:
Linux之日志
日志 在编写网络服务器, 各种软件时, 程序一定要打印一些日志信息. 1. 可以向显示器打印, 也可以向文件中写入. 2. 日志是软件在运行时记录的流水账, 用于排查服务进程挂掉的信息. 其中必须要有的是: 日志等级, 时间, 日志内容.可选的是文件名, 代码行数, 进程pid 等 日志…...
【LeetCode面试150】——202快乐数
博客昵称:沈小农学编程 作者简介:一名在读硕士,定期更新相关算法面试题,欢迎关注小弟! PS:哈喽!各位CSDN的uu们,我是你的小弟沈小农,希望我的文章能帮助到你。欢迎大家在…...
云原生之k8s服务管理
文章目录 服务管理Service服务原理ClusterIP服务 对外发布应用服务类型NodePort服务Ingress安装配置Ingress规则 Dashboard概述 认证和授权ServiceAccount用户概述创建ServiceAccount 权限管理角色与授权 服务管理 Service 服务原理 容器化带来的问题 自动调度:…...
【Vue】 npm install amap-js-api-loader指南
前言 项目中的地图模块突然打不开了 正文 版本太低了,而且Vue项目就应该正经走项目流程啊喂! npm i amap/amap-jsapi-loader --save 官方说这样执行完,就这结束啦!它结束了,我还没有,不然不可能记录这篇文…...
RocketMQ: 部署结构与存储特点
RocketMQ 是什么 它是一个队列模型的消息中间件,具有高性能、高可靠、高实时、分布式特点 Producer、Consumer、队列都可以分布式Producer 向一些队列轮流发送消息 队列集合称为 TopicConsumer 如果做广播消费则一个 consumer 实例消费这个 Topic 对应的所有队列如果…...
Android OpenGL ES详解——绘制圆角矩形
1、绘制矩形 代码如下: renderer类: package com.example.roundrectimport android.content.Context import android.opengl.GLES30 import android.opengl.GLSurfaceView.Renderer import com.opengllib.data.VertexArray import com.opengllib.prog…...
【大数据学习 | Spark】Spark的改变分区的算子
当分区由多变少时,不需要shuffle,也就是父RDD与子RDD之间是窄依赖。 当分区由少变多时,是需要shuffle的。 但极端情况下(1000个分区变成1个分区),这时如果将shuffle设置为false,父子RDD是窄依赖关系&…...
前端知识点---rest(javascript)
文章目录 前端知识点---rest(javascript)rest的用法基本语法特点使用场景与扩展运算符(spread)区别小练习 前端知识点—rest(javascript) rest出现于ES2015 function doSum(a,b, ...args) //示例中的args就是一个rest参数 //它会将后续的所有参数存储…...
Spark使用过程中的 15 个常见问题、详细解决方案
目录 问题 1:Spark 作业超时问题描述解决方案Python 实现 问题 2:内存溢出问题描述解决方案Python 实现 问题 3:Shuffle 性能问题问题描述解决方案Python 实现 问题 4:Spark 作业调度不均问题描述解决方案Python 实现 问题 5&…...
ASP.NET MVC宠物商城系统
该系统采用B/S架构,使用C#编程语言进行开发,以ASP.NET MVC框架为基础,以Visual Studio 2019为开发工具,数据库采用SQL Server进行保存数据。系统主要功能包括登录注册、宠物展示、个人中心、我的订单、购物车、用户管理、宠物类别…...
DQN系列算法详解
代码链接见文末 1. Q-learning 1.1 概述 Q-Learning是一种强化学习算法,目的是通过选择能带来最大长期收益的行为来完成任务。 做事包含瞬时奖励和记忆经验奖励: 在Q-Learning中,每个动作都会带来“瞬时奖励”,同时也会根据过去的经验记住哪些行为更有利。瞬时奖励: 这里…...
uniapp发布android上架应用商店权限
先看效果: 实现原理: 一、利用uni.addInterceptor的拦截器,在一些调用系统权限前拦截,进行弹窗展示,监听确定取消实现业务逻辑。 二、弹窗是原生nativeObj进行drawRect绘制的 三、权限申请调用使用的 plus.android.…...
已阻止加载“http://localhost:8086/xxx.js”的模块,它使用了不允许的 MIME 类型 (“text/plain”)。
记录今天解决的一个小bug 在终端启动8080端口号监听后,打开网址http://localhost:8080,发现不能正确加载页面,打开检查-控制台,出现如下警告:已阻止加载“http://localhost:8086/xxx.js”的模块,它使用了不…...
JavaEE之线程初阶(上)
前文我们知道计算机中的每一个程序都对应着一个进程,进程是CPU申请资源的最小单位,那么线程是什么呢,线程中我们又能学习到什么新的知识呢?? 我们来一探究竟 1. 认识线程(Thread) 线程是什么 …...
Spring Security @PreAuthorize注解
PreAuthorize 注解在 Spring Security 中提供了一种声明式的方法,可以在您的 Spring Boot 应用中添加方法级别的安全检查。本教程将引导您设置并有效使用 PreAuthorize,确保用户只能在具有特定角色或权限的情况下调用 REST API。 什么是 PreAuthorize&a…...
windows已建立威胁IP排查
在应急响应的时候,需要筛选出服务器建立连接的进程、PID,此代码可满足该需求实现共计2步 首先windos netstat-ano > all.txt, 上传至pycharm路径 第一步获取服务器建立连接的ip import re# 从文件读取 netstat 输出 def read_netstat_f…...
AI 大模型如何重塑软件开发流程?——技术革新与未来展望
人工智能的蓬勃发展为许多领域注入了强劲动力,而在软件开发这一关键技术领域,AI 大模型的应用正在彻底改变传统流程。从代码自动生成到智能测试,再到协同开发和流程优化,AI 正逐步成为软件开发者的得力助手,也推动企业…...
Admin.NET框架前端由于keep-alive设置缓存导致的onUnmount未触发问题
bug版本:next分支,基于.NET6版本; 问题描述: 1、添加keep-alive后,在其下运行的组件会出现onActived(被关注时)和onDeactived(取消关注时)生命周期,而组件原有生命周期为onMounted(被创造时)和onUnmounted(…...
Rest-assured
依赖 <--rest-assured依赖--><dependency><groupId>io.rest-assured</groupId><artifactId>rest-assured</artifactId><version>4.4.0</version><scope>test</scope> </dependency><--junit5依赖-->…...
ubuntu24挂载硬盘记录
1、显示硬盘及所属分区情况。在终端窗口中输入如下命令: sudo fdisk -l 找到自己硬盘的分区 我的地址/dev/sda 2、显示硬盘及所属分区情况。在终端窗口中输入如下命令,格式化自己硬盘: sudo mkfs -t ext4 /dev/sda 3、在终端窗口中输入如下…...
Dubbo集成SpringBoot实现远程服务调用
SpringBoot集成Dubbo Dubbo介绍了解 Dubbo 核心概念和架构dubbo特性dubbo运行原理图 SpringBoot集成Dubbo技术实战一、Dubbo Spring Boot 版本关系二、引入Maven依赖demo项目基础结构引入依赖创建每个模块1)api模块2)provider模块3)consumer模…...
Redis最终篇分布式锁以及数据一致性
在前三篇我们几乎说完了Redis的所有的基础知识以及Redis怎么实现高可用性,那么在这一篇文章中的话我们主要就是说明如果我们使用Redis出现什么问题以及解决方案是什么,这个如果在未来的工作中也有可能会遇到,希望对看这篇博客的人有帮助,话不多说直接开干 一.Hotkey以及BigKey…...
TCP协议
报文格式 源/目的端口号:数据从哪个进程来,到哪个进程去32位序号:TCP传输过程中,在发送端出的字节流中,传输报文中的数据部分的每一个字节都有它的编号32位确认号:标识了报文接收端期望接收的字节序列4位首…...
Vue3 源码解析(十):watch 的实现原理
本篇文章笔者会讲解 Vue3 中侦听器相关的 api:watchEffect 和 watch 。在 Vue3 之前 watch 是 option 写法中一个很常用的选项,使用它可以非常方便的监听一个数据源的变化,而在 Vue3 中随着 Composition API 的写法推行也将 watch 独立成了一…...
2023年9月GESPC++一级真题解析
一、单选题(每题2分,共30分) 题号 123456789101112131415 答案 CDBCDBACACBBDDA 1. 我们通常说的 “ 内存 ” 属于计算机中的()。 A. 输出设备 B. 输 ⼊ 设备 C. 存储设备 D. 打印设备 【答案】 C 【考纲知识点】…...
vscode 远程连接ssh 密钥方式
目录 1. powershell 生成key: 2. 在服务器上安装公钥 linux测试成功: 3).为了确保连接成功,输入如下指令以保证以下文件权限正确: 3 开启 ssh 密钥登录 vscode 远程连接配置 python连接测试ok 查看日志: 1. po…...
字符函数和字符串函数
字符分类函数 C语言中有⼀系列的函数是专门做字符分类的,也就是⼀个字符是属于什么类型的字符的。 这些函数的使用都需要包含⼀个头文件:ctype.h 这些函数的用法非常类似。 int islower ( int c )islower是能够判断参数部分是否是小写字母的。 通过返…...
如何利用ChatGPT加速开发与学习:以BPMN编辑器为例
在现代开发中,开发者经常会遇到各种需要编写和学习新技术的任务。ChatGPT作为一种强大的自然语言处理工具,不仅可以辅助编写代码,还可以帮助学习新的编程概念和解决开发中的难题。本文将以开发一个BPMN(业务流程建模与标注&#x…...
深度学习2
四、tensor常见操作 1、元素值 1.1、获取元素值 tensor.item() 返回tensor的元素;只能在一个元素值使用,多个报错,当存在多个元素值时需要使用索引进行获取到一个元素值时在使用 item。 1.2、元素值运算 tensor对元素值的运算:…...
工业生产安全-安全帽第二篇-用java语言看看opencv实现的目标检测使用过程
一.背景 公司是非煤采矿业,核心业务是采选,大型设备多,安全风险因素多。当下政府重视安全,头部技术企业的安全解决方案先进但价格不低,作为民营企业对安全投入的成本很敏感。利用我本身所学,准备搭建公司的…...
单片机学习笔记 9. 8×8LED点阵屏
更多单片机学习笔记:单片机学习笔记 1. 点亮一个LED灯单片机学习笔记 2. LED灯闪烁单片机学习笔记 3. LED灯流水灯单片机学习笔记 4. 蜂鸣器滴~滴~滴~单片机学习笔记 5. 数码管静态显示单片机学习笔记 6. 数码管动态显示单片机学习笔记 7. 独立键盘单片机学习笔记 8…...
c++ 力扣题(1)JZ64
JZ64求123...n_牛客题霸_牛客网 因此不能使用等差求和(禁掉位运算为了禁掉等差求和,右移一位就是等差除二)、循环、递归来解决 我们运用到在 统计构造次数所学到的内容: 1.可以利用静态全局变量的思想来做 2.构造n次对象&…...
logback动态获取nacos配置
文章目录 前言一、整体思路二、使用bootstrap.yml三、增加环境变量四、pom文件五、logback-spring.xml更改总结 前言 主要是logback动态获取nacos的配置信息,结尾完整代码 项目springcloudnacosplumelog,使用的时候、特别是部署的时候,需要改环境&#…...
基于零相差前馈补偿的 PID 控制
零相差前馈补偿是一种结合前馈补偿与反馈控制的策略,旨在提高控制系统对参考信号的跟踪精度。通过设计合理的前馈补偿器,使得系统对参考输入实现零相位差的跟踪,同时利用 PID 控制器保证系统的稳定性和动态性能。 1. 原理概述 目标ÿ…...
任务通知的本质(任务通知车辆运行) 软件定时器的本质(增加游戏音效)
任务通知的本质 没有任务通知 所谓"任务通知",你可以反过来读"通知任务"。 我们使用队列、信号量、事件组等等方法时,并不知道对方是谁。使用任务通知时,可 以明确指定:通知哪个任务。 使用队列、信号量、…...
如何在 MySQL 中进行数据导入和导出?
在 MySQL 中进行数据的导入和导出是一项常见的任务,用于数据备份、恢复、迁移以及数据分析等多种用途。MySQL 提供了多种方法来进行数据的导入和导出,每种方法都有其适用的场景和特点。以下是几种常用的 MySQL 数据导入和导出方法,包括命令行…...
python语言基础-5 进阶语法-5.3 流式编程
声明:本内容非盈利性质,也不支持任何组织或个人将其用作盈利用途。本内容来源于参考书或网站,会尽量附上原文链接,并鼓励大家看原文。侵删。 5.3 流式编程(参考链接:https://www.zhihu.com/question/59062…...
centos 服务器 docker 使用代理
宿主机使用代理 在宿主机的全局配置文件中添加代理信息 vim /etc/profile export http_proxyhttp://127.0.0.1:7897 export https_proxyhttp://127.0.0.1:7897 export no_proxy"localhost,127.0.0.1,::1,172.171.0.0" docker 命令使用代理 例如我想在使用使用 do…...
[个人专属博客] - docker安装
🎉🎉🎉🎉🎉🎉 欢迎访问的个人博客:http://swzbk.site/,加好友,一起赚🧧🧧🧧 🎉🎉🎉🎉&…...
推荐一个QDirStat基于 Qt 的目录统计工具
QDirStat 是一款基于 Qt 的目录统计工具,旨在帮助用户分析磁盘空间使用情况并进行清理。QDirStat的一些主要特点和功能: 跨平台兼容性:QDirStat 支持 Linux、BSD、Unix-like 系统以及 macOS,确保了广泛的用户基础。 直观的数据展…...
yolo自动化项目实例解析(九) 导航
比如我们经常使用的导航,说白了就是寻找两点之间最近的路径,也就是所谓的寻路,我们需要想办法让程序知道他要去哪里,路径包含(起点、轨迹、终点) 一、录制轨迹 从平面角度来看,我们可以把区域视…...
MySQL 报错:1137 - Can‘t reopen table
MySQL 报错:1137 - Can’t reopen table 1. 问题 对临时表查询: select a.ts_code,a.tsnum,b.tsnum from (select t.ts_code ,count(*) tsnum from tmp_table t group by t.ts_code having count(*) > 20 and count(*)< 50 ) a ,(select t.ts_…...
Bokeh实现大规模数据可视化的最佳实践
目录 引言 一、Bokeh简介 二、安装Bokeh 三、数据准备 四、性能优化 五、创建图表 六、添加交互功能 七、应用案例 八、高级技巧 九、总结 引言 在数据科学领域,数据可视化是一个至关重要的环节。通过可视化,我们可以直观地理解数据的特征和趋势,为数据分析和决策…...
HTMLCSS:比赛记分卡
效果演示 这段 HTML 和 CSS 代码创建了一个卡片式的体育比赛信息展示组件,用于显示篮球比赛的两个队伍名称、比赛时间、比分以及一些装饰性的视觉元素。 HTML <div class"card"><div data-status"inprogress" class"teams"…...
什么是 Faiss?
好的,我来详细解释 Faiss,它的用途、使用场景,以及如何安装和使用。 什么是 Faiss? Faiss 是由 Facebook AI Research 开发的一个开源库,专门用于高效的相似性搜索和聚类。它非常擅长在高维向量空间中进行快速搜索&a…...
【prism】遇到一个坑,分享!
背景 我通用prism的方式写了一个弹窗,弹窗绑定一个 Loaded 事件,但是Loaded事件一直不触发!!! 具体过程 我的loaded事件也是通过命令的方式绑定的: <i:Interaction.Triggers><i:EventTrigger EventName="Loaded...
vue制作代码比较工具
前两天朋友问我 有没有vue可以做一个json代码在线比较工具 我也是在网上搜了一下找到的 废话不说 直接上代码 采用 v3 pnpm i v-code-diff <div><CodeDiff:old-string"oldStr":new-string"newStr"output-format"side-by-side"/>…...
GPT系列文章
GPT系列文章 GPT1 GPT1是由OpenAI公司发表在2018年要早于我们之前介绍的所熟知的BERT系列文章。总结:GPT 是一种半监督学习,采用两阶段任务模型,通过使用无监督的 Pre-training 和有监督的 Fine-tuning 来实现强大的自然语言理解。在 Pre-t…...
Qt实现可拖拽的矩形
之前项目上需要用Qt来绘制可拖拽改变形状的矩形。看了Qt Graphics相关的内容,虽然对Qt怎么添加图元的有了些了解,但是具体如何实现拖拽效果,一时也没有什么好的想法。还好网上有人分享的例子,很受启发。后来又回顾了一下这部分的代…...
python爬虫初体验(五)—— 边学边玩小游戏
1. 打开浏览器 利用webbrowser 模块的 open()函数可以启动一个新浏览器,打开指定的 URL。 import webbrowser webbrowser.open(http://inventwithpython.com/) 2. 猜数字游戏 # -*- coding: utf-8 -*- # This is a guess the number game. import randomsecretN…...