[Qt的学习日常]--常用控件3

news2024/11/23 4:01:50

前言

作者:小蜗牛向前冲

名言:我可以接受失败,但我不能接受放弃

  如果觉的博主的文章还不错的话,还请点赞,收藏,关注👀支持博主。如果发现有问题的地方欢迎❀大家在评论区指正

目录

 一、显示类控件

1、Label

2、LCD Number

 3、ProgressBar

 4、Calendar Widget

二、输出类控件 

1、QLineEdit

2、TextEdit

3、ComboBox

 4、其他核心输出控件

本期:主要学习输入和输出控件

 一、显示类控件

1、Label

Qt中,QLabel 是一个用于显示文本或图像的控件。它常用于创建静态文本标签、图片显示或在UI中展示非交互内容

核⼼属性如下

属性

说明

text

QLabel中的

textFormat

本的格式.
Qt::PlainText
Qt::RichText 本(持html标签)

Qt::MarkdownText markdown格式
Qt::AutoText 根据本内容动决定本格式.

pixmap

QLabel 内部包含的图.

scaledContents

设为true表内容动拉伸填充 QLabel
设为false则不会动拉伸

alignment

⻬⽅式.
可以设置
平和垂直向如何对.

wordWrap

设为true内部的本会动换.
设为false则内部本不会动换.

indent

设置本缩进.平和垂直向都效.

margin

内部本和边框之间的边距.
不同于于indent,但是是上下左右四个
向都同时有效.
indent最多只是两个向有效(具体哪两个向有效取决于alignment)

openExternalLinks

是否允许打开个外部的链接.
(当QLabel
本内容包含url的时候涉及到)

buddy

给QLabel关联个"伙伴",这样点击QLabel时就能激活对应的伙伴.
例如伙伴如果是
个QCheckBox,那么该QCheckBox就会被选中.

显示图片:

在ui设计中,使用一个label控件

在widget.cpp中编写 

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);

    //设置label和窗口一样大
    ui->label->setGeometry(0,0,800,600);

    QPixmap pixmap(":/qt.png");
    ui->label->setPixmap(pixmap);

    //设置内容伸缩
    ui->label->setScaledContents(true);//但是我们拖动窗口,图片的大小不会和窗口大小进行变动

}

void Widget::resizeEvent(QResizeEvent *event)
{
    // 可以直接通过 this->width() 和 this->height() 设置 label 新的尺⼨, 也可以通event 参数拿到新的尺⼨.
     ui->label->setGeometry(0, 0, this->width(), this->height());
//    ui->label->setGeometry((0,0,event->size().width(),event->size().height()));
   qDebug() << event->size();
}

此处的 resizeEvent 函数我们没有⼿动调⽤,但是能在窗⼝⼤⼩变化时被⾃动调⽤.
这个过程就是依赖C++中的多态来实现的.Qt框架内部管理着QWidget对象表⽰咱们的窗
⼝.在窗⼝⼤⼩发⽣改变时,Qt就会⾃动调⽤ resizeEvent 函数.
但是由于实际上这个表⽰窗⼝的并⾮是QWidget,⽽是QWidget的⼦类,也就是咱们⾃⼰写
的Widget.此时虽然是通过⽗类调⽤函数,但是实际上执⾏的是⼦类的函数(也就是我们重写
后的 resizeEvent ).
此处属于是多态机制的⼀种经典⽤法.通过上述过程,就可以把⾃定义的代码,插⼊到框架内
部执⾏.相当于"注册回调函数".

 这里会显示一个全部的图片,而且当我们拖动窗口,图片尺寸也会变化  设置文本

    在ui中设置了二个label标签,并且有&

此处把label中的⽂本设置为"快捷键&A"这样的形式.其中&后⾯跟着的字符,就是快捷键.可以通过alt+A的⽅式来触发该快捷键.

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);
    //设置label的伙伴widget buddy
    ui->label->setBuddy(ui->radioButton);
    ui->label_2->setBuddy(ui->radioButton_2);
}

2、LCD Number

在Qt中,QLCDNumber 是一个用于显示数字的控件,通常用于模拟液晶数字显示器。QLCDNumber 可以显示整数或浮点数,并支持多种进制(如十进制、十六进制等)。

核⼼属性

属性

说明

intValue

QLCDNumber 的数字值(int).

value

QLCDNumber 的数字值(double).
和intValue是联动的.
例如给value设为1.5,intValue的值就是2.
另外,设置value和intValue的
法名字为 display ,不是 setValue
setIntValue .

digitCount

⽰⼏位数字.

mode

数字显形式.
1. QLCDNumber::Dec 进制模式,显常规的进制数字。
2. QLCDNumber::Hex 六进制模式,以六进制格式显数字。
3. QLCDNumber::Bin 进制模式,以进制格式显数字。
4. QLCDNumber::Oct 进制模式,以进制格式显数字。
只有进制的时候才能显⽰⼩数点后的内容.

segmentStyle

设置显⽰⻛格.
1. QLCDNumber::Flat :平的显⽰⻛格,数字呈现在个平坦的表上。
2. QLCDNumber::Outline :轮廓显⽰⻛格,数字具有清晰的轮廓和阴影效
果。

3. QLCDNumber::Filled :填充显⽰⻛格,数字被填充颜并与背景区分
开。

smallDecimalPoint

设置数点.

 代码示例:倒计时

1)在界⾯上创建⼀个 QLCDNumber ,初始值设为10.
objectName lcdNumbe

2)修改widget.h代码,创建⼀个 QTimer 成员,和⼀个 updateTime 函数

    QTimer* timer;

    void updateTime();

 修改widget.cpp,在构造函数中初始化 QTimer  

QTimer 表⽰定时器.通过 start ⽅法启动定时器之后,就会每隔⼀定周期,触发⼀次
QTimer::timeout 信号.
使⽤ connect QTimer::timeout 信号和 Widget::updateTime 连接起来,意味着每
次触发 QTimer::timeout 都会执⾏ Widget::updateTime

3)修改widget.cpp,在构造函数中初始化 QTimer 

QTimer 表⽰定时器.通过 start ⽅法启动定时器之后,就会每隔⼀定周期,触发⼀次
QTimer::timeout 信号.
使⽤ connect QTimer::timeout 信号和 Widget::updateTime 连接起来,意味着每
次触发 QTimer::timeout 都会执⾏ Widget::updateTime  

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);

    //创建timer实例
    timer = new QTimer(this);
    //连接信号和槽,每隔一段时间触发timeout信号,把timeout信号和槽函数updateTime连接起来
    connect(timer,&QTimer::timeout,this,&Widget::updateTime);
    //启动QTimer,每隔1000ms
    timer->start(1000);
    //qt为了保证线程安全,所有对界面的操作必须在主线程中完成

}

4)修改widget.cpp,实现 updateTime

通过 intValue 获取到 QLCDNumber 内部的数值.
如果value的值归0了,就停⽌ QTimer .接下来 QTimer 也就不会触发timeout信号了.

void Widget::updateTime()
{
    qDebug()<<"updateTime";
    int value = ui->lcdNumber->intValue();
    if(value<=0)
    {
        //时间到停止计时
        timer->stop();
        return ;
    }
    ui->lcdNumber->display(value-1);
}

 运行程序,时间就开始不断更新

 对于上面的代码,大家可以会有二个想法:

我可以不可以直接在Widget构造函数中,通过⼀个循环+sleep的⽅式是否可以呢?

这里显然是不可以的,因为循环会导致Widget的构造函数⽆法执⾏完毕,此时界⾯是不能正确构造和显⽰的.

那可不可以在Widget构造函数中,另起⼀个线程,在新线程中完成循环+sleep是否可以呢?

这里也是不可以的 Qt中规定,任何对于GUI上内容的操作,必须在主线程中完成.像Widget构造
函数,以及connect连接的slot函数,都是在主线程中调⽤的.⽽我们⾃⼰创建的线程则不是.
当我们⾃⼰的线程中尝试对界⾯元素进⾏修改时,Qt程序往往会直接崩溃.

这样的约定主要是因为GUI中的状态往往是牵⼀发动全⾝的,修改⼀个地⽅,就需要同步的对
其他内容进⾏调整.
⽐如调整了某个元素的尺⼨,就可能影响到内部的⽂字位置,或者其他元素的位置.这⾥⼀连串
的修改,都是需要按照⼀定的顺序来完成的.
由于多线程执行的顺序⽆法保障,因此Qt从根本上禁⽌了其他线程修改GUI状态,避免后续的
⼀系列问题.

 3、ProgressBar

在Qt中,QProgressBar 是一个用于显示任务进度的控件。你可以使用 QProgressBar 来向用户展示任务的完成进度,例如文件下载、数据处理等。QProgressBar 可以是确定性的(有明确的最小值和最大值)或不确定性的(显示为一个持续动画,以表明任务正在进行)。 

核⼼属性

属性

说明

minimum

进度条最

maximum

进度条最

value

进度条当前值

alignment

本在进度条中的对⻬⽅式.

Qt::AlignLeft :左对
Qt::AlignRight :右对
Qt::AlignCenter :居中对
Qt::AlignJustify :两端对

textVisible

进度条的数字是否可.

orientation

进度条的向是平还是垂直

invertAppearance

是否是朝反向增进度

textDirection

本的朝向.

format

的数字格式.
%p :表进度的百分(0-100)
%v :表进度的数值(0-100)
%m :表剩余时间(以毫秒为单位)
%t :表总时间(以毫秒为单位

案例:

在ui界面中创建一个显示进度条控件

 修改widget.h,创建 QTimer updateProgressBar 函数

    QTime* timer;
    void updateProgressBar();

修改widget.cpp,初始化 QTimer
此处设置100ms触发⼀次timeout信号.也就是⼀秒钟触发10次

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);

    timer = new QTimer(this);
    connect(timer,&QTimer::timeout,this,&Widget::updateProgressBar);
    timer->start(100);
}

修改widget.cpp,实现 updateProgressBar

void Widget::updateProgressBar()
{
    int value = ui->progressBar->value();
    if (value >= 100) {
        timer->stop();
        return;
    }
    ui->progressBar->setValue(value + 1);
}

 4、Calendar Widget

在Qt框架中,QCalendarWidget是一个用于显示和选择日期的日历控件。它提供了一个直观的界面,允许用户通过点击日历来选择日期。

核⼼属性

属性

说明

selectDate

当前选中的

minimumDate

⼩⽇

maximumDate

⼤⽇

firstDayOfWeek

每周的第天(也就是历的第列)是周.

gridVisible

是否显表格的边框

selectionMode

是否允许选择

navigationBarVisible

历上标题是否显

horizontalHeaderFormat

历上标题显期格式

verticalHeaderFormat

历第列显的内容格式

dateEditEnabled

是否允许期被编辑

 重要信号

信号

说明

selectionChanged(const
QDate&)
当选中的期发改变时发出

activated(constQDate&)

当双击个有效的期或者按下回键时发出,形参是个QDate类型,保存
了选中的

currentPageChanged(int,
int)

当年份份改变时发出,形参表改变后的新年份和

在界⾯上创建⼀个 QCalendarWidget 和⼀个label :  objectName calendarWidget , label  

 

QCalendarWidget 添加slot函数

void Widget::on_calendarWidget_selectionChanged()
{
    QDate date = ui->calendarWidget->selectedDate();
    qDebug() << date;
    ui->label->setText(date.toString());
}

二、输出类控件 

1、QLineEdit

在Qt框架中,QLineEdit是一个用于接收单行文本输入的小部件(widget)。它提供了一个简单的文本框,用户可以在其中输入和编辑文本。QLineEdit是一个非常常用的控件,常用于表单、对话框和各种用户输入场景。

核⼼属性

属性

说明

text

框中的

inputMask

内容格式约束

maxLength

⼤⻓

frame

是否添加边框

echoMode

⽰⽅式.
QLineEdit::Normal :这是默认值,本框会显本。
QLineEdit::Password :在这种模式下,输的字符会被隐藏,
通常
星号(*)或等号(=)代替。
QLineEdit::NoEcho :在这种模式下,本框不会显任何输
的字符。

cursorPosition

光标所在位置

alignment

字对⻬⽅式,设置平和垂直向的对.

dragEnabled

是否允许拖拽

readOnly

是否是只读的(不允许修改)

placeHolderText

当输框内容为空的时候,显什么样的提信息

clearButtonEnabled

是否会动显出"清除按钮".

 代码⽰例:验证两次输⼊的密码⼀致

在界面创建二个输入框和一个lable

编写代码,设置两个输⼊框的echoMode 为 Password 

Widget::Widget(QWidget *parent)
: QWidget(parent)
, ui(new Ui::Widget)
{
    ui->setupUi(this);
    ui->lineEdit->setEchoMode(QLineEdit::Password);
    ui->lineEdit_2->setEchoMode(QLineEdit::Password);
}

 给两个输⼊框设置 textEdited slot函数

void Widget::on_lineEdit_textEdited(const QString& arg1)
{
    const QString& s1 = ui->lineEdit->text();
    const QString& s2 = ui->lineEdit_2->text();
    if (s1.isEmpty() && s2.isEmpty())
    {
        ui->label->setText("密码为空!");
    }
    else if (s1 == s2) {
        ui->label->setText("两次输⼊的密码相同!");
    }
    else {
        ui->label->setText("两次输⼊的密码不同!");
    }
}


void Widget::on_lineEdit_2_textEdited(const QString& arg1)
{
	const QString& s1 = ui->lineEdit->text();
	const QString& s2 = ui->lineEdit_2->text();
	if (s1.isEmpty() && s2.isEmpty()) {
		ui->label->setText("密码为空!");
	}
	else if (s1 == s2) {
		ui->label->setText("两次输⼊的密码相同!");
	}
	else {
		ui->label->setText("两次输⼊的密码不同!");
	}
}

当我们输入相同密码的时候,就会提示密码相同

2、TextEdit

在Qt框架中QTextEdit是一个多行的文本编辑控件,用于显示和编辑富文本或纯文本。QLineEdit不同,QTextEdit可以处理多行文本,并且支持各种文本格式和样式。

核心属性

属性

说明

markdown

框内持有的内容.持markdown格式.能够动的对markdown本进
渲染成html

html

框内持有的内容.可以部分html标签.包括img和table等.

placeHolderText

框为空时提的内容.

readOnly

是否是只读的

undoRedoEnable

是否开启undo/redo功能.
按下ctrl+z触发undo
按下ctrl+y触发redo

autoFormating

开启动格式化.

tabstopWidth

按下缩进占多少空间

overwriteMode

是否开启覆盖写模式

acceptRichText

是否接收富⽂本内容                                          

 核⼼信号

信号

说明

textChanged()

本内容改变时触发

selectionChanged()

选中范围改变时触发

cursorPositionChanged()

光标移动时触发

undoAvailable(bool)

可以进undo操作时触发

redoAvailable(bool)

可以进redo操作时触发

copyAvaiable(bool)

本被选中/取消选中时触发

代码⽰例:获取多⾏输⼊框的内容

创建ui控件


 

给多⾏输⼊框添加slot函数.处理 textChanged 信号.

void Widget::on_textEdit_textChanged()
{
    const QString& content = ui->textEdit->toPlainText();
    qDebug()<<content;
    ui->label->setText(content);
}

运行输入,将输入框中的内容同步到Lable中, 


 

3、ComboBox

  在Qt框架中,QComboBox是一个用于显示下拉列表的控件。它允许用户从预定义的选项列表中进行选择。QComboBox可以显示静态列表,也可以动态添加和删除项目。

核心属性

属性说明

currentText

当前选中的⽂本

currentIndex

当前选中的条⽬下标.从0开始计算.如果当前没有条被选中,值为-1

ditable是否允许修改
设为true时,
QComboBox 为就常接近 QLineEdit ,也可以
设置
validator
iconSize 下拉框图标()⼤⼩

核⼼⽅法

说明

addItem(constQString&)

添加个条

currentIndex()

获取当前条的下标
从0开始计算.如果当前没有条
被选中,值为-1

currentText()

获取当前条本内容.

 核⼼信号

说明

activated(int)
activated(constQString&text)

⽤户选择了个选项时发出.这个时候相当于⽤户点开下拉框,并且标划过某个选项.此时还没有确认做出选择.

currentIndexChanged(int)
currentIndexChanged(constQString
&text)

当前选项改变时发出.此时⽤⼾已经明确的选择了个选项.
⽤⼾操作或者通过程序操作都会触发这个信号.

editTextChanged(constQString&
text)

当编辑框中的本改变时发出
(editable为true时有效)

 代码⽰例:⽤下拉框模拟⻨当劳点餐

 在ui界面中创建三个下拉框comboBox

在widget.cpp中初始化下拉框中条目的内容 ,并且添加对应的slot函数

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);

    //给下拉框添加条目
    ui->comboBox->addItem("汉堡1");
    ui->comboBox->addItem("汉堡包2");

    ui->comboBox_2->addItem("小吃1");
    ui->comboBox_2->addItem("小吃2");

    ui->comboBox_3->addItem("饮料1");
    ui->comboBox_3->addItem("饮料2");
}

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


void Widget::on_pushButton_clicked()
{
    qDebug()<<"汉堡选择"<<ui->comboBox->currentText();
    qDebug()<<"小吃选择"<<ui->comboBox_2->currentText();
    qDebug()<<"饮料选择"<<ui->comboBox_3->currentText();
}

 4、其他核心输出控件

其他有一些非常核心的控件:SpinBox,DateEdit&TimeEdit,Dial,Slider。这些控件的都无非要学习其核心属性和核心方法,这里就不为大家一一解析了,大家可以不清楚的直接可以去查官方的文档

在Qt框架中,QSpinBox是一个用于接收整数输入的控件。它提供了一个数字输入框和上下箭头,用户可以通过点击箭头或直接输入来改变数字值。QSpinBox还允许设置最小值、最大值和步长

 对于这种微调框,在点餐系统中就是,数量的选择。

在Qt框架中,QDateEditQTimeEdit是两个控件,分别用于处理日期和时间的输入。它们提供了一个类似于QLineEdit的输入框,并附带上下箭头,用户可以通过点击箭头或直接输入来改变日期和时间的值。

这二个控件的核心点就是能够处理日期和时间,我们就可以依靠这二个控件完成一个简单的日期计算器

在Qt框架中,QDial是一个圆形的控件,类似于旋钮,用于接收用户的输入值QDial的工作方式类似于QSlider,但它具有圆形界面,使其更适合某些类型的应用程序,例如音量控制、亮度调整等。 

Dial就是如下图的一个圆形控件,这里我们用dial来控制窗口的透明度.

 在Qt框架中,QSlider是一个用于接收用户输入的控件,它提供了一个滑动条,用户可以通过拖动滑块来选择一个数值。QSlider可以设置为水平或垂直方向,常用于音量控制、进度条等场景。

这个其实和Dial控件的用途非常类似,无非就是状态上的区别

 这里我们让slider控制窗口的大小

核心控件的细节非常多,大家光靠看文档还是很难掌握,大家还是要多多使用。 

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

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

相关文章

猫头虎分享已解决Bug || 前端领域技术问题解析

原创作者&#xff1a; 猫头虎 作者微信号&#xff1a; Libin9iOak 作者公众号&#xff1a; 猫头虎技术团队 更新日期&#xff1a; 2024年6月6日 博主猫头虎的技术世界 &#x1f31f; 欢迎来到猫头虎的博客 — 探索技术的无限可能&#xff01; 专栏链接&#xff1a; &…

06--jenkins构建CI_CD

前言&#xff1a;上一篇文章整理了git的部署和使用&#xff0c;这章主要复习持续集成软件Jenkins&#xff0c;这个技术现在在云计算方面也是有应用的&#xff0c;同时也是越高级越智能的软件代表。 1、概念简介 1&#xff09;jenkins是什么 Jenkins是一个开源的、可扩展的持…

C++学习/复习15--栈与队列概述及练习/deque/适配器的概念

1.1stack概念 1.2stack函数 1.3最小栈 1.4栈的压入弹出 1.5逆波兰表达式 1.6栈实现队列 1.7层序遍历 1.8stack模拟实现 2.1queue概念 2.2queue函数 2.3queue模拟实现 3.1deque适配器 3.2deque功能 3.3deque原理 3.4deque特点与适配器

Windows下切换JDK版本

&#x1f4d6;Windows下切换JDK版本 ✅1. 下载JEnv✅2. 安装JEnv✅3. 添加JDK✅4. 切换JDK 前提条件&#xff1a;电脑得装有至少2个JDK版本 ✅1. 下载JEnv github地址&#xff1a;https://github.com/FelixSelter/JEnv-for-Windows/releases ✅2. 安装JEnv 1.将下载好的JEnv…

TP5400 SOIC-8 1A 锂电池充电和 5V/1A 升压控制芯片

TP5400 作为一款高集成度的电池充电管理和升压控制芯片&#xff0c;其应用领域不仅仅局限于智能手机&#xff0c;还可以广泛应用于其他各种便携设备。以下是一些潜在的应用例子&#xff1a; 1.平板电脑&#xff1a;平板电脑同样依赖于锂电池作为电源&#xff0c;并且需要高效的…

经验分享,在线文本比较工具

这里分享一个在线文本比较工具&#xff0c;打开网页即用&#xff0c;很方便 网址&#xff1a; https://www.jq22.com/textDifference 截图&#xff1a;

专业技能篇---计算机网络篇

文章目录 前言计算机网络基础一、网络分层模型 HTTP一、从输入URL到页面显示发生了什么&#xff1f;二、Http的状态码有哪些&#xff1f;三、 HTTP与HTTPS有什么区别&#xff1f;四、URI 和 URL 的区别是什么?五、Cookie和Session有什么区别&#xff1f;六、GET与POST 前言 主…

ArrayList泛型存储类型以及Arraylist与数组的转换

1.泛型的存储类型 众所周知&#xff0c;ArrayList< E>泛型能够存储所有的对象类型&#xff0c;如String、对象、以及基本类型的包装类。 java中所有的基本类型如下&#xff1a; 那么&#xff0c;泛型< E>能否存储int[]&#xff0c;String[]数组这种类型呢&#…

思科配置路由器,四台主机互相ping通

一、如图配置 PC4和PC5用来配置路由器&#xff0c;各ip、接口如图所示。 二、配置各主机ip、子网掩码SNM、默认网关DGW (一)、PC0 (二)、PC1 (三)、PC2 (四)、PC3 三、 配置路由器Router0 (期间报错是打错了字母) Router>en Router#configure terminal Enter configurat…

为什么传统 CNN 可能无法进行基于纹理的分类?

作者&#xff1a;Mayank Gubba、Mohammed Faisal、Trapti Kalra、Vijay Pandey 将纹理分析与深度学习结合使用对于在机器视觉任务中取得更好的结果起着重要作用。在第一篇博客中&#xff0c;我们讨论了“纹理”的基础知识、不同类型的纹理以及纹理分析在解决实际计算机视觉任务…

TCGAbiolinks包学习

TCGAbiolinks 写在前面学习目的GDCquery GDCdownload GDC prepare中间遇到的报错下载蛋白质数据 写在前面 由于别人提醒我TCGA的数据可以利用TCGAbiolinks下载并处理&#xff0c;所以我决定阅读该包手册&#xff0c;主要是该包应该是有更新的&#xff0c;我看手册进行更新了&…

美国原装二手KEITHELY2410替代新品keithley2470数字源表

Keithley 2470 高压 SourceMeter 源测量单元 (SMU) 仪器将先进的 Touch, Test, Invent 技术带到您的指尖。它将创新的图形用户界面 (GUI) 与电容式触摸屏技术相结合&#xff0c;使测试变得直观&#xff0c;并最大限度地缩短学习曲线&#xff0c;帮助工程师和科学家更快地学习、…

DBeaver windows下载、安装与连接数据库

下载 官网下载地址&#xff1a;https://dbeaver.io/download/ 安装 1、双击安装 2、下一步…… 选择所有用户 3、组件选择 配置连接数据库 下载驱动

从0到1,揭秘AI产品经理的高薪秘诀,转型之路与实战资源全解析

前言 随着算法模型的日益精进、计算能力的显著提升以及海量数据的积累&#xff0c;人工智能领域正以前所未有的速度蓬勃发展。 在国家政策的积极推动、社会资本的强劲注入下&#xff0c;人工智能产业正处于技术快速进步的黄金时期&#xff0c;其影响力广泛渗透至教育智能化、…

061、Python 包:模块管理

包&#xff08;Package&#xff09;是一种用于组织模块的层次结构。包实际上就是一个包含了__init__.py文件的目录&#xff0c;该文件可以为空或包含包的初始化代码。通过使用包&#xff0c;可以更好地组织和管理大型项目中的模块&#xff0c;避免命名冲突&#xff0c;并提高代…

全网最全 Kimi 使用手册,看完 Kimi 效率提升 80%

在当前AI文字大模型领域&#xff0c;ChatGPT4.0无疑是最强大。然而&#xff0c;最近最火爆的大模型非国产Kimi莫属。 相较于其它大模型&#xff0c;Kimi 最大的优势在于&#xff0c;超长文本输入&#xff0c;支持200万汉字&#xff0c;是全球范围内罕见的超长文本处理工具&…

孟德尔随机化R包:TwoSampleMR和MR-PRESSO安装

1. 孟德尔随机化R包 看一篇文章&#xff0c;介绍孟德尔随机化分析&#xff0c;里面推荐了这两个R包&#xff0c;安装了解一下&#xff1a; Methods:Genome-wide association study (GWAS) data for autoimmune diseases and AMD were obtained from the IEU Open GWAS databas…

vue中通过自定义指令实现一个可拖拽,缩放的弹窗

效果 功能描述 按住头部可拖拽鼠标放到边框&#xff0c;可缩放多层重叠丰富的插槽&#xff0c;易于扩展 示例 指令代码 export const dragDialog {inserted: function (el, { value, minWidth 400, minHeight 200 }) {// 让弹窗居中let dialogHeight el.clientHeight ?…

在Linux系统中安装凸语言

凸语言在2023国产编程语言蓝皮书中的介绍如下&#xff1a; 凸语言gitee页面&#xff1a;凸语言: tu-lang 是一种动态类型编译型的通用编程语言, 已实现自举 (gitee.com) 使用git克隆源码&#xff1a; git clone https://github.com/tu-lang/tu.git 安装凸语言环境&#xff1a…

1.4k star 项目 CMakeTutorial 阅读和点评

1.4k star 项目 CMakeTutorial 阅读和点评 文章目录 1.4k star 项目 CMakeTutorial 阅读和点评0. 概要1. CUDA 目录2. FindPackage 目录3. Installation 目录4. PackageManage 目录5. PythonExtension 目录6. ImportExternalProject 目录总结 0. 概要 在 github 搜索关键字 CM…