【Qt】控件概述(4)—— 输出类控件

news2024/10/6 9:10:19

输出类控件

  • 1. QLineEdit——单行输入框
  • 2. QTextEdit——多行输入框
  • 3. QComboBox——下拉框
  • 4. QSpinBox——微调框
  • 5. QDateEdit && QTimeEdit && QDateTimeEdit
  • 6 QDial——旋钮
  • 7. QSlider——滑动条

1. QLineEdit——单行输入框

QLineEdit是一个单行的输入框,可以进行输入,但是不能进行换行,只能输入一样内容。

核心属性:

属性说明
text输入框中的文本
inputMask输⼊内容格式约束
maxLength最大长度
frame是否添加边框
echoMode显示方式.1:QLineEdit::Normal :这是默认值,文本框显示输⼊的文本。2:QLineEdit::Password :在这种模式下,输入的字符会被隐藏,通常用星号(*)或等号(=)代替。3:QLineEdit::NoEcho :在这种模式下,文本框不会显示任何输入的字符。
cursorPosition光标所在位置
alignment文字对齐方式,设置水平和垂直方向的对齐.
dragEnabled是否允许拖拽
readOnly是否是只读的(不允许修改)
placeHolderText当输⼊框内容为空的时候,显示什么样的提示信息
clearButtonEnabled是否会自动显示出"清除按钮"

核心信号:

属性说明
void cursorPositionChanged(int old, int new)当鼠标移动时发出此信号,old为先前的位置,new为新位置。
void editingFinished()当按返回或者回车键时,或者行编辑失去焦点时,发出此信号。
void returnPressed()当返回或回车键按下时发出此信号.如果设置了验证器,必须要验证通过,才能触发.
void selectionChanged()当选中的文本改变时,发出此信号。
void textChanged(const QString &text)当QLineEdit中的文本改变时,发出此信号,text是新的文本。代码对文本的修改能够触发这个信号.
void textEdited(const QString &text))当QLineEdit中的文本改变时,发出此信号,text是新的文本。代码对文本的修改不能触发这个信号.
Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);
    // 设置姓名输入框
    ui->lineEdit_name->setPlaceholderText("请输入名称:");
    ui->lineEdit_name->setClearButtonEnabled(true);

    // 设置电话输入框
    ui->lineEdit_phone->setPlaceholderText("请输入电话:");
    // 设置电话输入格式
    ui->lineEdit_phone->setInputMask("000-0000-0000");
    ui->lineEdit_phone->setClearButtonEnabled(true);

    // 设置密码输入框
    ui->lineEdit_password->setPlaceholderText("请输入密码:");
    ui->lineEdit_password->setEchoMode(QLineEdit::Password);
    ui->lineEdit_password->setClearButtonEnabled(true);
}

Widget::~Widget()
{
    delete ui;
}

void Widget::on_pushButton_clicked()
{
    QString male = ui->radioButton_male->isEnabled() ? "男" : "女";
    qDebug() << "姓名" << ui->lineEdit_name->text()
             << "性别:" << male
             << "电话:" << ui->lineEdit_phone->text()
             << "密码:" << ui->lineEdit_password->text();
}

在这里插入图片描述
代码样例1:使用正则表达式实现规定电话输入格式
正则表达式是一种计算机中常用到的技术,使用特殊字符来描述一串字符特征机制。

参考文档:
正则表达式文档:https://learn.microsoft.com/zh-cn/powershell/module/microsoft.powershell.core/about/about_regular_expressions?view=powershell-7.4
正则表达式在线工具:https://regextester.buyaocha.com/

  1. 使用QRegExp创建一个正则表达式对象
  2. 使用QRegExpValidator创建一个验证器对象,Qt中内置了四个主要的验证器对象

在这里插入图片描述

  1. 给lineEdit创建一个槽函数
  2. 通过lineEdit->validator()获取到内置的验证器
  3. 通过validate方法验证文本是否符合条件,涉及到两个参数,一个是QString&这里没有const,因为槽函数的中的字符串是带const所以这里我们要二外进行处理,另一个是int&是一个输出型参数,当验证字符串不匹配时,返回不匹配的下标。validate返回的是一个枚举QValidator::Acceptable表示验证通过,QValidator::Invalid表示验证失败。
Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);
    // 一开始设置按钮不可点击,只有输入正确的电话号码后才可以点击提交
    ui->pushButton->setEnabled(false);
    
    // 给lineEdit注册一个 validator验证器
    ui->lineEdit->setValidator(new QRegExpValidator(QRegExp("^1//d{10}$")));
}

Widget::~Widget()
{
    delete ui;
}

void Widget::on_lineEdit_textEdited(const QString &arg1)
{
    QString str = arg1;
    int pos = 0;
    if(ui->lineEdit->validator()->validate(str, pos) == QValidator::Acceptable){
        // 验证通过,设置按钮的可用状态为启动
        ui->pushButton->setEnabled(true);
    }else{
        // 验证失败,设置按钮的可用状态位禁止
        ui->pushButton->setEnabled(false);
    }
}

上述的正则表达式"^1\d{10}$"

  • ^+1的表示是数字1开头
  • \d表示数字,这里为了迎合C++的转所以使用\ \
  • {10}使用花括号包起来的数字表示可以重复10次
  • $表示结束符号

在这里插入图片描述
代码样例2:验证两次密码输入一致

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);
    // 一开始设置按钮为禁用状态,只有两次密码相同后才可以启用
    ui->pushButton->setEnabled(false);

    // 设置来个lineEdit的方式为Password
    ui->lineEdit->setEchoMode(QLineEdit::Password);
    ui->lineEdit_2->setEchoMode(QLineEdit::Password);

    // 设置label
    ui->label->setText("请输入一样的密码");
}

Widget::~Widget()
{
    delete ui;
}

void Widget::on_lineEdit_2_textEdited(const QString &arg1)
{
    QString password = ui->lineEdit->text();
    if (password == arg1){
        ui->pushButton->setEnabled(true);
        ui->label->setText("验证成功,可以进行提交");
    }else{
        ui->pushButton->setEnabled(false);
        ui->label->setText("密码不一致,其重新输入");
    }
}

在这里插入图片描述
同时我们还可以添加一个显示密码的功能。

void Widget::on_checkBox_toggled(bool checked)
{
    if(checked){
        ui->lineEdit->setEchoMode(QLineEdit::Normal);
    }else{
        ui->lineEdit->setEchoMode(QLineEdit::Password);
    }
}

void Widget::on_checkBox_2_toggled(bool checked)
{
    if(checked){
        ui->lineEdit_2->setEchoMode(QLineEdit::Normal);
    }else{
        ui->lineEdit_2->setEchoMode(QLineEdit::Password);
    }
}

在这里插入图片描述

2. QTextEdit——多行输入框

QTextEdit表示多行输入框,可以支持富文本输入和MarkDown,并且可以在超出文本框时添加滚轮。

核心属性:

属性说明
toPlainText获取文本内容
textCursor获取鼠标选中的内容,返回一个QTextCursor类,该类中selectedText获取鼠标选中的字符,position获取光标的位置。
markdown输入框内持有的内容.支持markdown格式.能够自动的对markdown文本进渲染成html,html 输入框内持有的内容.可以支持大部分html标签.包括img和table等.
placeHolderText输入框为空时提示的内容.
readOnly是否是只读的
undoRedoEnable是否开启undo/redo功能.按下ctrl+z触发undo,按下ctrl+y触发redo
autoFormating开启自动格式化.
tabstopWidth按下缩进占多少空间
overwriteMode是否开启覆盖写模式
acceptRichText是否接收富文本内容
verticalScrollBarPolicy垂直方向滚动条的出现策略1:Qt::ScrollBarAsNeeded :根据内容自动决定是否需要滚动条。这是默认值。2:Qt::ScrollBarAlwaysOff :总是关闭滚动条。3:Qt::ScrollBarAlwaysOn :总是显示滚动条。
horizontalScrollBarPolicy水平方向滚动条的出现策略1:Qt::ScrollBarAsNeeded :根据内容自动决定是否需要滚动条。这是默认值。2:Qt::ScrollBarAlwaysOff :总是关闭滚动条。3:Qt::ScrollBarAlwaysOn :总是显示滚动条。

核心信号

信号说明
textChanged()文本内容改变时触发
selectionChanged()选中范围改变时触发
cursorPositionChanged()光标移动时触发
undoAvailable(bool)可以进行undo操作时触发
redoAvailable(bool)可以进行redo操作时触发
copyAvaiable(bool)文本被选中/取消选中时触发
void Widget::on_textEdit_textChanged()
{
    const QString& content = ui->textEdit->toPlainText();
    qDebug() << content;
}

在这里插入图片描述

代码样例:使用剩余的信号:

void Widget::on_textEdit_selectionChanged()
{
    QTextCursor cursor = ui->textEdit->textCursor();
    qDebug() << "[selectionChanged]:" << cursor.selectedText();
}

void Widget::on_textEdit_cursorPositionChanged()
{
    QTextCursor cursor = ui->textEdit->textCursor();
    qDebug() << "[cursorPositionChanged]:" <<  cursor.position();
}

void Widget::on_textEdit_redoAvailable(bool b)
{
    qDebug() << "[redoAvailable]:" << b;
}

void Widget::on_textEdit_undoAvailable(bool b)
{
    qDebug() << "[undoAvailable]:" << b;
}

void Widget::on_textEdit_copyAvailable(bool b)
{
    qDebug() << "[copyAvailable]:" << b;
}

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

3. QComboBox——下拉框

核心属性:

属性说明
currentText当前选中的文本
currentIndex当前选中的条目下标.从0开始计算.如果当前没有条目被选中,值为-1
editable是否允许修改,设为true时,QComboBox 的行为就非常接近 QLineEdit , 也可以设置 validator
iconSize下拉框图标(小三角)的大小
maxCount最多允许有多少个条目

核心方法

方法说明
addItem(const QString&)添加⼀个条目
currentIndex()获取当前条目的下标从0开始计算.如果当前没有条目被选中,值为-1
currentText()获取当前条目的文本内容.

核心信号

方法说明
activated(int),activated(const QString& text)当用户选择了⼀个选项时发出.这个时候相当于用户点开下拉框,并且鼠标划过某个选项.此时还没有确认做出选择.
currentIndexChanged(int),currentIndexChanged(const QString& text)当前选项改变时发出.此时用户已经明确的选择了⼀个选项.用户操作或者通过程序操作都会触发这个信号.
editTextChanged(const QString& text)当编辑框中的文本改变时发出(editable 为true时有效)

代码样例:添加选项

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);
    ui->comboBox->addItem("选项一");
    ui->comboBox->addItem("选项二");
    ui->comboBox->addItem("选项三");
}

void Widget::on_comboBox_currentIndexChanged(const QString &arg1)
{
    qDebug() << arg1;
}

void Widget::on_comboBox_activated(const QString &arg1)
{
    qDebug() << arg1;
}

在这里插入图片描述
代码样例:从文件中读取

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);
    std::ifstream file("C:/Users/chuyang/Desktop/config.txt");
    if (!file.is_open()){
        qDebug() << "open file error";
    }
    std::string line;
    while (std::getline(file, line)){
        ui->comboBox->addItem(QString::fromStdString(line));
    }
}

在这里插入图片描述

4. QSpinBox——微调框

使用QSpinBox 或者QDoubleSpinBox 表示"微调框",它是带有按钮的输入框.可以用来输入整数/浮点数.通过点击按钮来修改数值大小。由于QSpinBox 和QDoubleSpinBox 用法基本相同,就只介绍QSpinBox 的使用了.

QSpinBox的关键属性:

属性说明
value存储的数值
setRange设置范围
singleStep每次调整的"步长".按下⼀次按钮数据变化多少.
displayInteger数字的进制.例如displayInteger设为10,则是按照10进制表示.设为2则为2进制;
minimum最小值
maximum最大值
suffix后缀
prefix前缀
wrapping是否允许换行
frame是否带边框
alignment文字对齐方式.
readOnly是否允许修改
buttonSymbol按钮上的图标.1:UpDownArrows 上下箭头形式。2:PlusMinus 加减号形式。3:NoButtons 没有按钮
accelerated(加速的) 按下按钮时是否为快速调整模式
correctionMode输⼊有误时如何修正。1:QAbstractSpinBox::CorrectToPreviousValue :如果用户输入了⼀个无效的值(例如,在只能显示正整数的SpinBox中输⼊了负数),那么SpinBox会恢复为上⼀个有效值。例如,如果SpinBox的初始值是1,用户输⼊了-1(无效),然后SpinBox会恢复为1。2:QAbstractSpinBox::CorrectToNearestValue :如果用户输⼊了⼀个无效的值,SpinBox会恢复为最接近的有效值。例如,如果SpinBox的初始值是1,用户输⼊了-1(无效),那么SpinBox会恢复为0。
keyboardTrack是否开启键盘跟踪.设为true,每次在输⼊框输⼊⼀个数字,都会触发⼀次valueChanged()和textChanged()信号.设为false,只有在最终按下enter或者输⼊框失去焦点,才会触发valueChanged()和textChanged()信号.

核心信号

信号说明
textChanged(QString)微调框的文本发生改变时会触发.参数QString带有前缀和后缀.
valueChanged(int)微调框的⽂本发⽣改变时会触发.参数int,表⽰当前的数值.
Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);
    ui->comboBox->addItem("选项一");
    ui->comboBox->addItem("选项二");
    ui->comboBox->addItem("选项三");

    ui->comboBox_2->addItem("选项1");
    ui->comboBox_2->addItem("选项2");
    ui->comboBox_2->addItem("选项3");

    ui->comboBox_3->addItem("选项Ⅰ");
    ui->comboBox_3->addItem("选项Ⅱ");
    ui->comboBox_3->addItem("选项Ⅲ");

    ui->spinBox->setValue(1);
    ui->spinBox->setRange(1,5);
    ui->spinBox_2->setValue(1);
    ui->spinBox_2->setRange(1,5);
    ui->spinBox_3->setValue(1);
    ui->spinBox_3->setRange(1,5);
}

void Widget::on_pushButton_clicked()
{
    qDebug() << ui->comboBox->currentText() << ":" << ui->spinBox->value()
             << ui->comboBox_2->currentText() << ":" << ui->spinBox_2->value()
             << ui->comboBox_3->currentText() << ":" << ui->spinBox_3->value();
}

在这里插入图片描述
在这里插入图片描述

5. QDateEdit && QTimeEdit && QDateTimeEdit

使用QDateEdit 作为日期的微调框.
在这里插入图片描述

使用QTimeEdit 作为时间的微调框.
在这里插入图片描述

使用QDateTimeEdit 作为时间⽇期的微调框.
在这里插入图片描述
这几个控件用法非常相似,我们以QDateTimeEdit 为例进行介绍.

QDateTimeEdit核心属性:

属性说明
dateTime时间日期的值.形如2000/1/1 0:00:00
date单纯日期的值.形如2001/1/1
time单纯时间的值.形如0:00:00
displayFormat时间日期格式.形如yyyy/M/d H:mm ( y 表示年份),(M 表示月份)(d 表示日期)(H 表示小时)(m 表示分钟)(s 表示秒)
minimumDateTime最小时间日期
maximumDateTime最大时间日期
timeSpec• Qt::LocalTime :显示本地时间。• Qt::UTC :显示协调世界时(UTC)。• Qt::OffsetFromUTC :显示相对于UTC的偏移量(时差).

核心信号:

信号说明
dateChanged(QDate)日期改变时触发.
timeChanged(QTime)时间改变时触发.
dateTimeChanged(QDateTime)时间日期任意⼀个改变时触发.

代码显示:实现两个日期之间的天数计算

void Widget::on_pushButton_clicked()
{
    QDateTime oldtime = ui->dateTimeEdit->dateTime();
    QDateTime newtime = ui->dateTimeEdit_2->dateTime();

    int days = oldtime.daysTo(newtime); // Qt中提供了计算天数和秒数的函数,
    // 但是这里不建议使用daysTo因为从文档中我们可以发现不到一天的时间但是跨天的也算一天
    // 所以如果要算准确的时间建议使用
    // int hours = (oldtime.secsTo(newtime) / 3600) / 24;
    int hours = (oldtime.secsTo(newtime) / 3600) % 24;

    QString text = QString("oldtime距离newtime  ") + QString::number(days) +
    QString(" 天 零 ")
     + QString::number(hours) + QString(" 个⼩时!");
     ui->label->setText(text);
}

在这里插入图片描述

6 QDial——旋钮

核心属性:

属性说明
value持有的数值.
minimum最小值
maximum最大值
singleStep按下方向键的时候改变的步长
pageStep按下pageUp/pageDown的时候改变的步长.
sliderPosition界面上旋钮显示的初始位置
tracking外观是否会跟踪数值变化.默认值为true.⼀般不需要修改.
wrapping是否允许循环调整.即数值如果超过最大值,是否允许回到最小值.(调整过程能否 “套圈”)
notchesVisible是否显示刻度线
notchTarget刻度线之间的相对位置.数字越⼤,刻度线越稀疏.

核心信号

属性说明
valueChanged(int)数值改变时触发
rangeChanged(int,int)范围变化时触发

代码样例:通过旋转调整窗口的不透明度

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);
    ui->dial->setRange(0, 100);
    // 设置允许循环
    ui->dial->setWrapping(true);
    // 设置刻度线
    ui->dial->setNotchesVisible(true);
    // 设置刻度线的刻度
    ui->dial->setNotchTarget(3.7);
}

void Widget::on_dial_valueChanged(int value)
{
    this->setWindowOpacity((double)value / 100);
}

7. QSlider——滑动条

QSlider 和QDial 都是继承自QAbstractSlider ,因此用法上基本相同.

核心属性:

属性说明
value持有的数值.
minimum最小值
maximum最大值
singleStep按下方向键的时候改变的步长
pageStep按下pageUp/pageDown的时候改变的步长
sliderPosition滑动条显示的初始位置
tracking外观是否会跟踪数值变化.默认值为true.⼀般不需要修改.
orientation滑动条的方向是水平还是垂直
invertedAppearance是否要翻转滑动条的方向
tickPosition刻度的位置.
tickInterval刻度的密集程度.

核心信号

属性说明
valueChanged(int)数值改变时触发
rangeChanged(int,int)范围变化时触发

代码样例:通过滑动条改变窗口大小

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);
    ui->horizontalSlider->setMinimum(500);
    ui->horizontalSlider->setMaximum(2000);
    ui->horizontalSlider->setSingleStep(50);

    ui->verticalSlider->setMinimum(500);
    ui->verticalSlider->setMaximum(1500);
    ui->verticalSlider->setSingleStep(50);
}

void Widget::on_horizontalSlider_valueChanged(int value)
{
    QRect rect = this->geometry();
    this->setGeometry(rect.x(), rect.y(), value, rect.height());
}

void Widget::on_verticalSlider_valueChanged(int value)
{
    QRect rect = this->geometry();
    this->setGeometry(rect.x(), rect.y(), rect.width(), value);
}

代码样例:实现自定义快捷键

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
	// 设置滑块的属性
    ui->setupUi(this);
    ui->horizontalSlider->setRange(0, 100);
    ui->horizontalSlider->setSingleStep(5);
    ui->horizontalSlider->setValue(0);
	
	// 创建快捷键
    QShortcut* shortcut1 = new QShortcut(this);
    QShortcut* shortcut2 = new QShortcut(this);
    shortcut1->setKey(QKeySequence("-"));
    shortcut2->setKey(QKeySequence("="));
    // 连接槽函数
    connect(shortcut1, &QShortcut::activated, this, &Widget::subvalue);
    connect(shortcut2, &QShortcut::activated, this, &Widget::addValue);
}

Widget::~Widget()
{
    delete ui;
}

void Widget::subvalue()
{
    int value = ui->horizontalSlider->value();
    qDebug() << value;
    if (value >= ui->horizontalSlider->minimum()){
        ui->horizontalSlider->setValue(value - 5);
    }
}

void Widget::addValue()
{
    int value = ui->horizontalSlider->value();
    qDebug() << value;
    if (value <= ui->horizontalSlider->maximum()){
        ui->horizontalSlider->setValue(value + 5);
    }
}

void Widget::on_horizontalSlider_valueChanged(int value)
{
    ui->label->setText(QString::number(value));
}

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2191553.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

BUU刷题-Pwn-shanghai2018_baby_arm(ARM_ROP_csu_init,ARM架构入门)

解题思路&#xff1a; 泄露或修改内存数据&#xff1a; 堆地址&#xff1a;无需栈地址&#xff1a;无需libc地址&#xff1a;无需BSS段地址&#xff1a;无需 劫持程序执行流程&#xff1a;ARM_ROP && mprotect函数(运行内存权限修改) && [[ARM_ROP_csu_init]…

【AI自然语言处理应用】通义晓蜜CCAI

通义晓蜜CCAI-对话分析AIO 对话分析AIO&#xff0c;即对话分析all-in-one API&#xff0c;是基于深度调优的对话大模型&#xff0c; 为营销服类产品提供智能化升级所需的生成式摘要总结、质检、分析等能力的官方应用。 面向对象&#xff1a;开发者、自研企业、传统呼叫中心采购…

02 nth_element 与第k小

题目&#xff1a; 方案一&#xff1a;sort排序 #include<bits/stdc.h> using namespace std;int main() {int n;int k;cin>>n>>k;int a[n]{0};for(int i0;i<n;i){cin>>a[i];}sort(a,an); cout<<a[k]<<endl;}方案二&#xff1a;…

【机器学习(十一)】糖尿病数据集分类预测案例分析—XGBoost分类算法—Sentosa_DSML社区版

文章目录 一、XGBoost算法二、Python代码和Sentosa_DSML社区版算法实现对比(一) 数据读入和统计分析(二)数据预处理(三)模型训练与评估(四)模型可视化 三、总结 一、XGBoost算法 关于集成学习中的XGBoost算法原理&#xff0c;已经进行了介绍与总结&#xff0c;相关内容可参考【…

leetcode面试题17.04:消失的数字(C语言版)

思路1 先排序&#xff0c;再依次查找&#xff0c;如果下一个值不等于前一个1&#xff0c;那么下一个值就是消失数字。 时间复杂度分析&#xff1a;冒泡排序的时间复杂度为O(N^2)&#xff0c;qsort排序时间复杂度为O(N*logN)。因此该思路不可行。 思路2 求和0到N&#xff0c;再减…

Python爬虫使用实例-mdrama

一个Python爬虫使用实例&#xff1a;主要用于下载指定的剧集音频。分别从网页和json文件中获取剧集的title和剧集中所存在音频的id&#xff0c;调用you-get&#xff0c;最后自动重命名下载文件夹为剧集名title。 目标网址&#xff1a; https://www.missevan.com/mdrama/其中为…

【C++】关键字+命名空间

大家好&#xff0c;我是苏貝&#xff0c;本篇博客带大家了解C的命名空间&#xff0c;如果你觉得我写的还不错的话&#xff0c;可以给我一个赞&#x1f44d;吗&#xff0c;感谢❤️ 目录 一. 关键字二. 命名空间2.1 命名空间的定义2.2 命名空间的使用a. 命名空间名称作用域限定…

R包的安装、加载以及如何查看帮助文档

0x01 如何安装R包 一、通过R 内置函数安装&#xff08;常用&#xff09; 1.安装CRAN的R包 install.packages()是一个用于安装 R 包的重要函数。 语法&#xff1a;install.packages(pkgs, repos getOption("repos"),...) 其中&#xff1a; pkgs&#xff1a;要安…

SpringCloud Alibaba - Eureka注册中心,Nacos配置中心

Eureka 1、创建服务端 server:port: 8761 # eureka 默认端口spring:application:name: eureka-server # 应用名称&#xff08;微服务中建议必须定义应用名称&#xff09; SpringBootApplication EnableEurekaServer // 开启eureka注册中心功能 public class EurekaServerAppli…

二分查找一>山脉数组的峰顶索引

1.题目&#xff1a; 2.解析&#xff1a; 代码&#xff1a; public int peakIndexInMountainArray(int[] arr) {int left 1, right arr.length-2;while(left < right) {int mid left (right-left1) / 2;if(arr[mid] > arr[mid-1]) left mid;else right mid-1;}ret…

【记录】Excel|Excel 打印成 PDF 页数太多怎么办

【记录】Excel&#xff5c;解决 Excel 打印成 PDF 页数过多的问题 文章目录 【记录】Excel&#xff5c;解决 Excel 打印成 PDF 页数过多的问题方法一&#xff1a;调整页边距WPS OfficeMicrosoft Excel 方法二&#xff1a;优化页面布局调整列宽和行高使用“页面布局”视图合并单…

Markdown实用语法汇总

说明&#xff1a; 本来只展示本人常用的、markdown特有优势的一些语法。表格输入markdown的弱项&#xff0c;不作介绍&#xff0c;借助软件创建即可。引用图片、音频、视频等&#xff0c;虽然很方便&#xff0c;但是内容集成度不高&#xff0c;需要上传发布的时候很不方便&…

[单master节点k8s部署]29.Istio流量管理(五)

测试istio熔断管理。 采用httpbin镜像和fortio镜像&#xff0c;其中httpbin作为服务端&#xff0c;fortio是请求端。这两个的配置yaml文件都在istio的samples/httpbin目录下&#xff0c;fortio的配置文件在samples-client目录下。 [rootmaster httpbin]# ls gateway-api ht…

七、Drf版本组件

七、版本组件 7.1基于GET请求 #url.py urlpatterns [ path(home/,views.HomeView.as_view(),namehome), ]#setting.py REST_FRAMEWORK {#定义版本号的名称&#xff0c;默认为versionVERSION_PARAM:version, #允许的版本号值&#xff0c;如果前端传递过来的版本号的值不在…

工具使用总结之(三) SecureCRT 设置日志自动保存

SecureCRT工具设置日志自动保存方法 1、双击打开SecureCRT工具 2、打开依次打开选项-》会话选项-》日志文件 3、按照如下截图方法进行配置&#xff0c;然后确定保存即可 [%Y%M%D_%h:%m:%s] [%Y%M%D_%h:%m:%s] [%h:%m:%s.%t]

统一 SASE 架构中的网络和安全融合

网络威胁情报技术的进步 传统的网络边界一片混乱&#xff0c;剩下的只是无人管理的设备、分散在私有云和公共云中的资产、无法读取的应用程序流量泛滥&#xff0c;混合工作结构正在给现有网络的功能带来压力。 更重要的是&#xff0c;这些问题早在生成式人工智能和大型语言模…

Nginx的核心架构和设计原理

Nginx 是一个免费的、开源的、高性能 Http 服务器和反向代理。Nginx 的架构设计是为了提供高性能、稳定性和可扩展性。 Nginx 的主要架构组件和工作原理&#xff1a; 1、Master 进程&#xff1a;Nginx 的运行始于一个 master 进程&#xff0c;它负责管理所有的工作进程。mast…

【C++差分数组】1526. 形成目标数组的子数组最少增加次数|1872

本文涉及知识点 C差分数组 LeetCode1526. 形成目标数组的子数组最少增加次数 给你一个整数数组 target 和一个数组 initial &#xff0c;initial 数组与 target 数组有同样的维度&#xff0c;且一开始全部为 0 。 请你返回从 initial 得到 target 的最少操作次数&#xff0c…

WSL2Linux 子系统(十二)

wsl 子系统安装 cuda 环境 《WSL2Linux 子系统(十一)》讲述 WSL 网络转为桥接模式的两种方法&#xff0c;WSL 网络桥接模式无论是静态 IP 还是动态分配 IP 均支持。本篇文章则是简单讲述 WSL 安装 cuda 环境。 作者&#xff1a;炭烤毛蛋 &#xff0c;点击博主了解更多。 提示…

3种框架助你绘制完美技术路线图,导师一眼就认可

我是娜姐 迪娜学姐 &#xff0c;一个SCI医学期刊编辑&#xff0c;探索用AI工具提效论文写作和发表。 一份好的技术路线图&#xff0c;不仅能让导师和评委一目了然地了解你的研究计划&#xff0c;还能为你的整个研究过程提供清晰的指导。但是&#xff0c;不少学生在制作时往往摸…