c++ qt 从身份证号码字符串获取性别信息

时间: 2023-12-29 08:05:33 浏览: 30
身份证号码中的第17位是性别标识,奇数表示男性,偶数表示女性。你可以通过以下代码来获取身份证号码字符串中的性别信息: ```cpp QString idCardNumber = "123456789012345678"; // 身份证号码字符串 int gender = idCardNumber.mid(16, 1).toInt(); // 获取第17位的数字并转化为整型 QString genderStr = (gender % 2 == 0) ? "女" : "男"; // 根据性别标识来确定性别字符串 ``` 其中,`mid()` 函数用于获取字符串中的一段子串,第一个参数表示起始位置,第二个参数表示子串的长度。`toInt()` 函数用于将字符串转化为整型。最后根据取模运算来确定性别字符串。
相关问题

c++ qt 效验身份证号码

在 C++ Qt 中,可以使用正则表达式来验证身份证号码的格式。以下是一个简单的示例代码: ```c++ #include <QRegularExpression> bool validateIDCard(QString idCard) { QRegularExpression regex("\\d{17}([0-9]|X)"); return regex.match(idCard).hasMatch(); } ``` 这里使用了一个正则表达式,它匹配一个 17 位数字和一个可选的数字或大写字母 X。如果给定的字符串与这个正则表达式匹配,那么它被认为是一个有效的身份证号码。你可以将这段代码放到一个类或函数中,以便在你的应用程序中使用。

c++ Qt 效验身份证号码 代码

以下是一个基于 Qt 的身份证号码验证代码: ```cpp QString idNumber = "110101199003077156"; // 身份证号码 QRegExp regExp("^(\\d{17})(\\d|[xX])$"); // 正则表达式匹配规则 if(regExp.exactMatch(idNumber)) { // 如果匹配成功 int factors[17] = {7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2}; // 加权因子 char checkCodes[11] = {'1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2'}; // 校验码 int sum = 0; // 加权和 for(int i = 0; i < 17; i++) { sum += (idNumber.at(i).digitValue() * factors[i]); // 乘以加权因子并求和 } int remainder = sum % 11; // 模11取余 QChar checkCode = checkCodes[remainder]; // 根据余数获取校验码 if(checkCode.toUpper() == idNumber.at(17).toUpper()) { // 校验码匹配成功 qDebug() << "身份证号码验证通过"; } else { qDebug() << "身份证号码校验码错误"; } } else { qDebug() << "身份证号码格式错误"; } ``` 这个代码首先使用正则表达式 `^(\\d{17})(\\d|[xX])$` 来匹配身份证号码的格式,如果格式匹配成功,就继续进行验证。验证的过程是根据身份证号码的前17位数字乘以对应的加权因子(加权因子从左到右依次为:7、9、10、5、8、4、2、1、6、3、7、9、10、5、8、4、2),然后将乘积求和并对11取余得到一个余数,再根据这个余数从预先定义的校验码数组中获取一个校验码,最后将这个校验码和身份证号码的最后一位进行比较,如果相同就认为身份证号码验证通过,否则就认为校验码错误。

相关推荐

最新推荐

recommend-type

C++实现数字转换为十六进制字符串的方法

主要介绍了C++实现数字转换为十六进制字符串的方法,涉及C++操作数字与字符串转换的相关技巧,需要的朋友可以参考下
recommend-type

详解C++ string常用截取字符串方法

string常用截取字符串方法有很多,但是配合使用以下两种,基本都能满足要求: find(string strSub, npos); find_last_of(string strSub, npos); 其中strSub是需要寻找的子字符串,npos为查找起始位置。找到返回子...
recommend-type

C++实现判断字符串是否回文实例解析

主要介绍了C++实现判断字符串是否回文,其中采用了数据结构中栈以及过滤字符等技术,,需要的朋友可以参考下
recommend-type

C++不使用变量求字符串长度strlen函数的实现方法

主要介绍了C++不使用变量求字符串长度strlen函数的实现方法,实例分析了strlen函数的实现原理与不使用变量求字符串长度的实现技巧,需要的朋友可以参考下
recommend-type

c++ 连接两个字符串实现代码 实现类似strcat功能

c++ 连接两个字符串实现代码 实现类似strcat功能,需要的朋友可以参考下
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

用matlab绘制高斯色噪声情况下的频率估计CRLB,其中w(n)是零均值高斯色噪声,w(n)=0.8*w(n-1)+e(n),e(n)服从零均值方差为se的高斯分布

以下是用matlab绘制高斯色噪声情况下频率估计CRLB的代码: ```matlab % 参数设置 N = 100; % 信号长度 se = 0.5; % 噪声方差 w = zeros(N,1); % 高斯色噪声 w(1) = randn(1)*sqrt(se); for n = 2:N w(n) = 0.8*w(n-1) + randn(1)*sqrt(se); end % 计算频率估计CRLB fs = 1; % 采样频率 df = 0.01; % 频率分辨率 f = 0:df:fs/2; % 频率范围 M = length(f); CRLB = zeros(M,1); for
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。