match_pro = r'\S:\s([0-9a-fA-F]{8}\s[0-9a-fA-F]{8}\s[0-9a-fA-F]{8}\s[0-9a-fA-F]{8})'正则匹配不上
时间: 2024-04-13 21:29:45 浏览: 118
对不起,我之前给出的正则表达式存在问题。如果您想要匹配格式为 `: 00000000 00000000 00000000 00000000` 的字符串,并提取其中的32位16进制数字部分,可以使用以下正则表达式:
```python
import re
pattern = r':\s([0-9A-Fa-f]{8}\s[0-9A-Fa-f]{8}\s[0-9A-Fa-f]{8}\s[0-9A-Fa-f]{8})'
text = ": 00000000 00000000 00000000 00000000"
matches = re.findall(pattern, text)
if matches:
print(matches[0])
```
这个正则表达式将匹配以冒号和空格开头的字符串,并提取其中的32位16进制数字部分。请确保在使用正则表达式时,输入的字符串与正则表达式的模式完全匹配,包括空格和冒号的位置。
相关问题
QRegExp rx("PRODUCT=([0-9a-fA-F]{1,4})/([0-9a-fA-F]{1,4})");
QRegExp是一个用于正则表达式的类,在Qt中常用于字符串模式匹配。这个特定的`QRegExp`实例`rx`是用来匹配一个特定的字符串格式,即"PRODUCT=xxxx/yyyy",其中`xxxx`和`yyyy`都是由1到4位的十六进制数字组成。这里的括号`(`和`)`是正则表达式中的分组,表示这两个部分将被视为独立的匹配单元。
`[0-9a-fA-F]`代表字符集,匹配从0到9,以及A到F(大小写均可)的十六进制数字。`{1,4}`则是量词,指定了前面的字符集合可以出现一次到四次。
例如,如果你有一个字符串"PRODUCT=1A2B/3C4D",使用这个正则表达式`rx`,它可以成功匹配"1A2B"和"3C4D"这两段。
要使用这个正则表达式,你可以创建一个新的`QRegEx`对象,并尝试在目标字符串上应用它,看是否能找到匹配:
```cpp
QRegExp rx("PRODUCT=([0-9a-fA-F]{1,4})/([0-9a-fA-F]{1,4})");
QString str = "PRODUCT=1A2B/3C4D";
if (rx.exactMatch(str)) {
QString productCode1 = rx.cap(1); // 第一个括号内的内容
QString productCode2 = rx.cap(2); // 第二个括号内的内容
// 进行后续操作...
}
```
以下shell脚本是什么意思,转换成python是什么样的。ComNvmeDevNameInfoGet() { local slot_info="$1" local ret_file="$2" local ctrl_str="$3" local slot_id="" local slot_temp="" local slot_id_get="" local contrl_num="" local test_scene="" local ctrl_id=0 ls /dev/ | grep "nvme[0-9]\{1,\}" | grep -v "nvme[0-9]\{1,\}n" >nvme_info.txt slot_id=$(echo "${slot_info}" | sed 's/^0*//g') slot_id=$[slot_id+0] slot_id=$[slot_id-1] set +x while read contrl_num || [[ ! -z ${contrl_num} ]] do if [ "0" == "${ctrl_id}" ];then find /sys/devices -name "${contrl_num}" > ${contrl_num}_bus_info.txt else rm -f ${contrl_num}_bus_info.txt dos2unix ${contrl_num}_bus_info.txt fi #兼容服务器的PCIE链路 if grep -iw "FT2-MP1" /root/TestPlat/common/test_scene.ini ;then slot_temp=$(cat ${contrl_num}_bus_info.txt | awk -F / '{print $5}' | awk -F "." '{print $2}') else slot_temp=$(cat ${contrl_num}_bus_info.txt | awk -F "/" '{print $7}' | cut -b 9-10) fi slot_id_get=$[0x${slot_temp}+0] if [ "${slot_id_get}" = "${slot_id}" ];then set -x echo "${slot_id}:/dev/${contrl_num}:Ctrl${ctrl_id}" echo "/dev/${contrl_num}" >"${ret_file}" return 0 fi done < nvme_info.txt set -x echo "$(date +"%y-%m-%d %H:%M:%S") can not get nvme controller ctrl${ctrl_id} info,slot${slot_info}." | tee -a error.txt return 1
这个shell脚本的作用是根据输入的slot_info(slot id)来获取对应的NVMe控制器的设备名,并将其输出到指定的文件中。具体流程如下:
1. 将所有/dev/目录下的名字类似于“nvme[0-9]”但不包含“nvme[0-9]n”的文件名存储在nvme_info.txt文件中。
2. 将输入的slot_info转换为十进制,并减去1,得到slot_id。
3. 遍历nvme_info.txt中的每个文件名,获取其对应的控制器编号contrl_num。
4. 根据contrl_num在/sys/devices目录下查找对应的总线信息文件,并将其存储在contrl_num_bus_info.txt文件中。
5. 根据服务器型号的不同,从contrl_num_bus_info.txt中提取出对应的PCIe插槽编号slot_temp。
6. 将slot_temp转换为十进制,得到slot_id_get。
7. 如果slot_id_get与slot_id相等,则将控制器设备名输出到ret_file文件中,并返回0表示成功。
8. 如果遍历完所有的文件名仍然没有找到对应的控制器设备名,则将错误信息输出到error.txt文件中,并返回1表示失败。
将其转换成Python代码大致如下:
```python
import os
import re
import datetime
def ComNvmeDevNameInfoGet(slot_info, ret_file, ctrl_str):
with open("nvme_info.txt", "w") as f:
for file in os.listdir("/dev/"):
if re.match("nvme[0-9]+", file) and not re.match("nvme[0-9]+n", file):
f.write(file + "\n")
slot_id = int(slot_info.lstrip("0"))
slot_id -= 1
ctrl_id = 0
with open("nvme_info.txt", "r") as f:
for contrl_num in f:
contrl_num = contrl_num.strip()
if ctrl_id == 0:
with open(f"/sys/devices/*/pci*/{contrl_num}/", "w") as bus_info_file:
bus_info_file.write(contrl_num)
else:
os.remove(f"{contrl_num}_bus_info.txt")
os.system(f"dos2unix {contrl_num}_bus_info.txt")
if "FT2-MP1" in open("/root/TestPlat/common/test_scene.ini").read():
with open(f"{contrl_num}_bus_info.txt", "r") as bus_info_file:
slot_temp = re.search(r"/pci([0-9a-fA-F]{2}).*/", bus_info_file.read()).group(1)
else:
with open(f"{contrl_num}_bus_info.txt", "r") as bus_info_file:
slot_temp = re.search(r"/pci.*/(.*):.*", bus_info_file.read()).group(1)[8:10]
slot_id_get = int(slot_temp, 16)
if slot_id_get == slot_id:
with open(ret_file, "w") as ret_file:
ret_file.write(f"/dev/{contrl_num}")
return f"{slot_id}:/dev/{contrl_num}:Ctrl{ctrl_id}"
ctrl_id += 1
with open("error.txt", "a") as error_file:
error_file.write(f"{datetime.datetime.now().strftime('%y-%m-%d %H:%M:%S')} can not get nvme controller ctrl{ctrl_id} info,slot{slot_info}.\n")
return 1
```