PCL点云库(2) - IO模块

news2024/11/17 22:32:19

目录

2.1 IO模块接口

2.2 PCD数据读写

(1) PCD数据解析

(2)PCD文件读写示例

2.3 PLY数据读写

(1)PLY数据解析

(2)PLY文件读写示例

2.4 OBJ数据读写

(1)OBJ数据解析

(2)OBJ文件读写示例

2.5 VTK数据读写

(1)VTK数据解析

(2)VTK文件读写示例

2.6 保存为PNG


2.1 IO模块接口

参考文章:PCL函数库摘要——IO模块_pcl/io_悠缘之空的博客-CSDN博客

(1)Class pcl::FileReader

类FileReader定义了PCD文件的读取接口,主要用做其他读取类的父类。

(2)Class pcl::FileWriter

类FileWriter 与 FileReader对应,是写人PCD文件的类接口定义,可以作为其它写入类的父类。

(3)Class pcl::Grabber

类Grabber为PCL1.X对应的设备驱动接口的基类定义。

(4)Class openni_wrapper::OpenNIDevice

类OpenNIDevice定义OpenNI设备的基类,继承该基类可以实现不同的OpenNI设备子类,用于获取包括红外数据、RGB数据、深度图像数据等。

(5)Class openni_wrapper::DeviceKinect

(6)Class openni_wrapper::DevicePrimesense

(7)Class openni_wrapper::DeviceXtionPro

以上3个类分别封装了Kinect,Primesense,XtionPro相关设备操作和数据获取操作实现,其详细接口参考其父类OpenNIDevice的关键函数说明。

(8)Class openni_wrapper::DeviceONI

封装了利用ONI文件回放虚拟类kinect设备的操作和数据获取操作实现,其详细接口参考其父类OpenNIDevice的关键函数说明。

(9)Class openni_wrapper::OpenNIDriver

类OpenNIDriver采用单例模式实现对底层驱动的封装,里面包含一xn::Context对象,提供给所有设备使用。该类提供了枚举和访问所有设备的方法实现。

(10)Class openni_wrapper::OpenNIException

类OpenNIException封装一般的异常处理实现。

(11)Class openni_wrapper::Image

类Image是简单的图像数据封装基类。

(12)Class openni_wrapper::ImageBayerGRBG

(13)Class openni_wrapper::ImageRGB24

(14)Class openni_wrapper::ImageYUV422 Class Reference

以上3个类分别实现了对原始数据 BayerGRBG ,RGB24、YUV422到图像转化接口,详细参考其父类关键函数说明。

(15)Class pcl::OpenNIGrabber

类OpenNIGrabber 实现对OpenNI设备(例如Primesense PSDK,MicrosoftKinect,Asus XTion Pro/Live)数据的采集接口,详细参考其父类Grabber 关键函数说明。

(16)Class pcl::PCDReader

(17)Class pcl::PLYReader

以上两个类分别是PCD、PLY文件格式读入接口的实现,详细参考其父类pcl: :FileReader。

(18)Class pcl::PLYWriter

(19)Class pcl::PCDWriter

以上两个类分别是PCD、PLY文件格式写出接口的实现,详细参考其父类pcl: :FileWriter。

(20)Class pcl::io::IOException

类pcl::io::IOException 是I/O相关的异常处理接口实现,详细参考其父类PCLEx-ception。

(21)I/O模块其他关键成员

 

2.2 PCD数据读写

(1) PCD数据解析

# .PCD v0.7 - Point Cloud Data file format
VERSION 0.7
FIELDS x y z _
SIZE 4 4 4 1
TYPE F F F U
COUNT 1 1 1 4
WIDTH 112099
HEIGHT 1
VIEWPOINT 0 0 0 1 0 0 0
POINTS 112099
DATA binary
  • VERSION 0.7:指定pcd文件的版本。
  • FIELDS:指定每个点可以具有的维度,以及每个维度所代表的含义。例如:FIELDS x y z r g b表示该点的位置信息(x,y,z),颜色信息(r,g,b)。
  • SIZE:以字节为单位指定每个数据所占用的内存。
  • TYPE:指定每个数据的数据类型。其中无效的点的通常存储为NAN类型。

            I:可表示int8,int16,int32。
            U:可表示uint8,unit16,uint32。
            F:表示float(上图所用的为浮点类型)。

  • COUNT:指定每个维度有多少元素。例如xyz数据通常只有一个元素。
  • WIDTH:指定数据点的宽度,它包含两个含义:(1)可指定点云总个数(与POINTS相同),用于无组织的数据。(2)可指定有组织点云数据的宽度(连续点的总数)。
  • HEIGTH: 指定数据点的高度,它包含两个含义:(1)可指定有组织的点云数据的高度(总行数)。(2)对未组织的数据,它被设置为1。
  • POINTS:指定点云总个数。
  • VIEWPOINT:采集数据时的视点(由平移tx,ty,tz和四元数qw,qx,qy,qz组成)。
  • DATA:点云数据存储的数据类型(支持ascii和binary)。如果以ASCII形式,每一点占据一个新行。

(2)PCD文件读写示例

cmake_minimum_required(VERSION 2.6)
project(pcd)
 
find_package(PCL 1.10 REQUIRED)
 
include_directories(${PCL_INCLUDE_DIRS})
link_directories(${PCL_LIBRARY_DIRS})
add_definitions(${PCL_DEFINITIONS})
 
add_executable(pcd pcd.cpp)
 
target_link_libraries (pcd ${PCL_LIBRARIES})
 
install(TARGETS pcd RUNTIME DESTINATION bin)
#include <iostream>
#include <pcl/point_cloud.h>
#include <pcl/io/pcd_io.h>
#include <pcl/visualization/pcl_visualizer.h>

using namespace std;

int main()
{
    pcl::PCDReader reader;
    pcl::PCLPointCloud2 org;
    pcl::io::loadPCDFile("../pcdfile.pcd",org);

    for(auto &f : org.fields)
    cout << f.name;

    pcl::PointCloud<pcl::PointXYZ> cloud;
    pcl::fromPCLPointCloud2<pcl::PointXYZ>(org,cloud);

    pcl::PCDWriter writer;
    pcl::io::savePCDFileBinaryCompressed("../savepcdfile.pcd",cloud);
    pcl::visualization::PCLVisualizer::Ptr viewer(new pcl::visualization::PCLVisualizer);
    viewer->setWindowName("PCDFile");
    viewer->addPointCloud(cloud.makeShared());
    while (!viewer->wasStopped())
    {
        viewer->spinOnce(100);
    }
    return 0;
}

 

2.3 PLY数据读写

(1)PLY数据解析

典型的PLY文件结构:

  • 头部
  • 顶点列表
  • 面片列表
  • 其他元素列表
ply
format ascii 1.0
element vertex 14806
property float x
property float y
property float z
property float nx
property float ny
property float nz
element face 0
property list uchar int vertex_indices
end_header
0.91441 -0.536438 0.822624 -0.0442205 -0.930906 0.362575
0.933494 -0.545228 0.820276 0.073409 -0.981856 0.174844
...

(2)PLY文件读写示例

cmake_minimum_required(VERSION 2.6)
project(ply)
 
find_package(PCL 1.10 REQUIRED)
 
include_directories(${PCL_INCLUDE_DIRS})
link_directories(${PCL_LIBRARY_DIRS})
add_definitions(${PCL_DEFINITIONS})
 
add_executable(ply ply.cpp)
 
target_link_libraries (ply ${PCL_LIBRARIES})
 
install(TARGETS ply RUNTIME DESTINATION bin)
#include <iostream>
#include <pcl/point_cloud.h>
#include <pcl/io/ply_io.h>
#include <pcl/visualization/pcl_visualizer.h>

using namespace std;

int main()
{
    pcl::PCLPointCloud2 cloud;
    pcl::io::loadPLYFile("../ply.ply",cloud);

    pcl::PLYReader reader;
    pcl::PLYWriter writer;

    pcl::PointCloud<pcl::PointXYZ> cloud1;
    pcl::fromPCLPointCloud2<pcl::PointXYZ>(cloud,cloud1);

    pcl::io::savePLYFile("saveply.ply",cloud,Eigen::Vector4f::Zero (),
                         Eigen::Quaternionf::Identity (),
                         true);

    pcl::visualization::PCLVisualizer::Ptr viewer(new pcl::visualization::PCLVisualizer);
    viewer->setWindowName("PLYFile");
    pcl::visualization::PointCloudColorHandlerGenericField<pcl::PointXYZ> color(cloud1.makeShared(), "y");
    viewer->addPointCloud(cloud1.makeShared(),color);
    viewer->setPointCloudRenderingProperties(pcl::visualization::PCL_VISUALIZER_POINT_SIZE,2);

    while(!viewer->wasStopped())
        viewer->spinOnce(100);

    return 0;
}

2.4 OBJ数据读写

(1)OBJ数据解析

mtllib cube.mtl
g default
v -0.500000 -0.500000 0.500000
v 0.500000 -0.500000 0.500000
v -0.500000 0.500000 0.500000
v 0.500000 0.500000 0.500000
v -0.500000 0.500000 -0.500000
v 0.500000 0.500000 -0.500000
v -0.500000 -0.500000 -0.500000
v 0.500000 -0.500000 -0.500000
vt 0.001992 0.001992
vt 0.998008 0.001992
vt 0.001992 0.998008
vt 0.998008 0.998008
...

mtllib:代表材质库,通常指向到某个mtl文件

  • v(vertices):几何形状的顶点,因为物体是由面构成的,而面是由线构成的,线由点构成的,所以无论是何形状,都必须要有几何顶点;一些应用支持顶点颜色,通过在x y z后面跟上red, green, blue值来表示。颜色值的范围为0到1.0。
  • vt(vertex texture):顶点纹理,代表当前顶点对应纹理图的哪个像素,通常是0-1,如果大于1,就相当于将纹理重新扩充然后取值,比如镜像填充、翻转填充之类的,然后根据纹理图的宽高去计算具体像素位置
  • vn(vertex normal):顶点法线,物理里面有说过眼睛看到物体是因为光线经过物体表面反射到眼睛,所以这个法线就是通过入射光线计算反射光线使用的法线。
  • f(face):大部分几何体都包括面,除非是像头发丝那一类模型只包含一根根头发的顶点,而且大部分模型的头发也用的面片的方法渲染的。

        其他参考:obj格式解析_obj格式详解_风翼冰舟的博客-CSDN博客

(2)OBJ文件读写示例

cmake_minimum_required(VERSION 2.6)
project(obj)
 
find_package(PCL 1.10 REQUIRED)
 
include_directories(${PCL_INCLUDE_DIRS})
link_directories(${PCL_LIBRARY_DIRS})
add_definitions(${PCL_DEFINITIONS})
 
add_executable(obj obj.cpp)
 
target_link_libraries (obj ${PCL_LIBRARIES})
 
install(TARGETS obj RUNTIME DESTINATION bin)
#include <iostream>

#include <pcl/point_cloud.h>
#include <pcl/io/obj_io.h>
#include <pcl/visualization/pcl_visualizer.h>

using namespace std;

int main()
{
    pcl::PolygonMesh mesh;
    pcl::PCLPointCloud2 cloud;
    pcl::TextureMesh tmesh;

#if 0
    pcl::io::loadOBJFile("../obj.obj",cloud);
    pcl::io::loadOBJFile("../obj.obj",mesh);
    pcl::io::loadOBJFile("../obj.obj",tmesh);
#else
    pcl::OBJReader objreader;
    objreader.read("../obj.obj",cloud);
    objreader.read("../obj.obj",mesh);
    objreader.read("../obj.obj",tmesh);
#endif

    pcl::io::saveOBJFile("../saveobj.obj",mesh);

    pcl::PointCloud<pcl::PointXYZ> cloudxyz;
    pcl::fromPCLPointCloud2<pcl::PointXYZ>(cloud,cloudxyz);

    pcl::visualization::PCLVisualizer::Ptr viewer(new pcl::visualization::PCLVisualizer);
    viewer->setWindowName("OBJFile");

    pcl::visualization::PointCloudColorHandlerGenericField<pcl::PointXYZ> color(cloudxyz.makeShared(), "z");
    viewer->addPointCloud(cloudxyz.makeShared(),color);
    viewer->setPointCloudRenderingProperties(pcl::visualization::PCL_VISUALIZER_POINT_SIZE,2);
    viewer->addPolygonMesh(mesh);

    while(!viewer->wasStopped())
        viewer->spinOnce(100);

    return 0;
}

2.5 VTK数据读写

(1)VTK数据解析

# vtk DataFile Version 2.0
vtk output
ASCII
DATASET POLYDATA
POINTS 2312 float
0.263107 0 0.425176 0.33131 0 0.374478 0.389942 0 0.312962 
0.43731 0 0.242405 0.472045 0 0.164845 0.493143 0 0.0825238 
  • 第一行是说明vtk文件的version(这是legacy 版本,此外还有较新的xml版本)
  • 第二行是文件描述,随便写什么
  • 第三行是ASCII或者BINARY
  • 第四行是说明数据类型,有STRUCTURED_POINTS,STRUCTURED_GRID,RECTILINEAR_GRID,POLYDATA
  • 后面为数据,它分为三个部分:POINTS 点数据,CELSS 网格数据,CELL_TYPES网格类型
     

(2)VTK文件读写示例

cmake_minimum_required(VERSION 2.6)
project(vtkfile)
 
find_package(PCL 1.10 REQUIRED)
find_package(VTK REQUIRED)

include(${VTK_USE_FILE})
link_directories(${VTK_LIBRARY_DIRS})
 
include_directories(${PCL_INCLUDE_DIRS})
link_directories(${PCL_LIBRARY_DIRS})
add_definitions(${PCL_DEFINITIONS})

add_executable(vtkfile vtkfile.cpp)
 
target_link_libraries (vtkfile ${PCL_LIBRARIES} ${VTK_LIBRARIES})
target_link_libraries (vtkfile ${VTK_LIBRARIES})
 
install(TARGETS vtkfile RUNTIME DESTINATION bin)
#include <iostream>
#include <pcl/point_cloud.h>
#include <pcl/io/vtk_io.h>
#include <pcl/io/vtk_lib_io.h>
#include <pcl/visualization/pcl_visualizer.h>
#include <pcl/io/obj_io.h>

using namespace std;

int main()
{
    pcl::PCLPointCloud2 cloud;
    pcl::PolygonMesh mesh,mesh1,mesh2;

#if 0
    pcl::io::loadPolygonFile("../vtk.vt",mesh);
#else
    pcl::io::loadPolygonFileVTK("../vtk.vtk",mesh);
    pcl::io::loadPolygonFileVTK("../vtk.vtk",mesh2);
#endif
    
    pcl::PointCloud<pcl::PointXYZ> cloudxyz;
    pcl::fromPCLPointCloud2<pcl::PointXYZ>(mesh.cloud,cloudxyz);

    pcl::visualization::PCLVisualizer::Ptr viewer(new pcl::visualization::PCLVisualizer);
    viewer->setWindowName("VTKFile");

    pcl::visualization::PointCloudColorHandlerGenericField<pcl::PointXYZ> color(cloudxyz.makeShared(),"y");
    viewer->addPointCloud(cloudxyz.makeShared(),color);
    viewer->setPointCloudRenderingProperties(pcl::visualization::PCL_VISUALIZER_POINT_SIZE,3);
    viewer->addPolygonMesh(mesh);

    while(!viewer->wasStopped())
        viewer->spinOnce(100);

    return 0;
}

 

2.6 保存为PNG

#include <iostream>
#include <pcl/point_cloud.h>
#include <pcl/io/pcd_io.h>
#include <pcl/io/png_io.h>
#include <pcl/visualization/pcl_visualizer.h>

using namespace std;

int main()
{

    pcl::PCDReader reader;
    pcl::PCLPointCloud2 org;

    pcl::io::loadPCDFile("../cow.pcd",org);

    for(auto &f : org.fields)
        cout << f.name << endl;

    pcl::PointCloud<pcl::PointXYZ> cloud;
    pcl::fromPCLPointCloud2<pcl::PointXYZ>(org,cloud);

    pcl::io::savePNGFile("../savepng.png",cloud,"rgb");
    pcl::visualization::PointCloudColorHandlerGenericField<pcl::PointXYZ> color(cloud.makeShared(), "z");
    pcl::visualization::PCLVisualizer::Ptr viewer(new pcl::visualization::PCLVisualizer);
    viewer->setWindowName("savePNG");
    viewer->addPointCloud(cloud.makeShared(),color);
    viewer->setPointCloudRenderingProperties(pcl::visualization::PCL_VISUALIZER_POINT_SIZE,2);
    
    while(!viewer->wasStopped())
        viewer->spinOnce(100);

    return 0;
}}

 

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

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

相关文章

网易云信 RTC 音频 QoS 综述

RTC、QoS、WebRTC 的定义 RTC 实时通信&#xff0c;泛指各种数据的实时传输技术&#xff0c;包括音频&#xff0c;视频&#xff0c;文本&#xff0c;图片等媒体和非媒体数据的实时传输。 QoS 服务质量&#xff0c;指一个网络能够利用各种基础技术&#xff0c;为指定的网络通信…

狂买GPU、四处挖人,马斯克:我要做理解宇宙的TruthGPT

来源: 爱范儿 微信号&#xff1a;ifanr 整理 | 凌敏、核子可乐 上个月&#xff0c;马斯克还积极呼吁叫停超强 AI 研发 6 个月&#xff0c;现在就坐不住了&#xff1f; 马斯克声称正在研究 TruthGPT 近日&#xff0c;马斯克在接受福克斯新闻频道的塔克卡尔森采访时宣布&#…

小红书投放预算如何制定,品牌规划

进行产品与品牌推广是一件相对复杂而全面的事。以小红书为例&#xff0c;当我们在制定产品投放传播方案时&#xff0c;确定平台投放预算是首要的。今天将为大家分享&#xff0c;如何制定小红书投放预算最为合理高效。 一、目的决定预算 在说明具体的预算计算方法之前&#xff0…

[数据库]MySQL窗口函数

1.窗口函数是什么 玛雅人造不出轮子,也不需要轮子. 在学完基础以后,通过子查询和聚合函数,理论上可以解决任何复杂的sql查询问题,但是人类发明出来轮子绝对不是用来看着它转圈的. 窗口函数和聚合函数非常相似,区别在于聚合函数是将多个行结合成一个结果,而窗口函数是以某个区…

webrtc janus服务器部署在公网,coturn转发媒体流

janus本身部署在公网时&#xff0c;其内部使用的libnice库已经实现了stun的功能&#xff0c;在配置文件janus.jcfg里面&#xff0c;nat_1_1_mapping配置成公网地址&#xff0c;其位于NAT后面的局域网客户端之间可以实现媒体流之间的分享&#xff0c;发布者将媒体流推到公网&…

【网络】-- https协议

目录 http协议 https协议 安全 概念 什么是"加密"&#xff1f; 为什么要加密&#xff1f; 常见的加密方式 对称加密 非对称加密 数据摘要 && 数据指纹 数字签名 HTTPS 的工作过程探究 方案一&#xff1a;只使用对称加密 方案二&#xff1a;只使…

深眸科技|制造行业升级速度加快,2D视觉与3D视觉该如何选择?

随着人工智能的不断发展&#xff0c;机器视觉已经成为当下最炙手可热的技术之一。在制造业转型升级并且迅猛发展的过程中&#xff0c;对于产品的高精度、零缺陷的需求也在不断提升&#xff0c;而机器视觉的出现为制造业产业升级提供了强有力的驱动力。 随着5G、AI等技术的不断…

174_技巧_Power BI 动态格式(万|亿)

174_技巧_Power BI 动态格式(万|亿) 一、背景 Power BI 2023年4月份更新&#xff0c;新增加了一个预览功能&#xff1a;动态格式(Dynamic format strings for measures)&#xff0c;度量值的结果可以动态的显示为不同的格式。 今天我们主要来看一个技巧&#xff0c;如何在 P…

[架构之路-171]-《软考-系统分析师》-5-数据库系统-1- 数 据 库 的 控 制 功 能(并发控制、性能优化)

目录 5 . 4 数 据 库 的 控 制 功 能 5.4.1 并发控制 1 . 事务的基本概念 2 . 数据不一致问题 3 . 封锁协议 4 . 死锁问题 5.4.2 数据库性能优化 1 . 硬件升级 2 . 数据库设计 5.4.3 数据库的完整性 1 . 完整性约束条件 2 . 实体完整性 3 . 参照完整性 4 . 用户定…

华为云-使用脚本初始化Linux数据盘

操作场景 本文以云服务器的操作系统为“CentOS 7.4 64位”为例&#xff0c;采用初始化数据盘脚本的方式为数据盘设置分区。 不同云服务器的操作系统的格式化操作可能不同&#xff0c;本文仅供参考。 须知&#xff1a; 首次使用磁盘时&#xff0c;如果您未参考本章节对磁盘执…

json for modern c++

目录 json for modern c概述编译问题问题描述问题解决 读取JSON文件demo json for modern c GitHub - nlohmann/json: JSON for Modern C 概述 json for modern c是一个德国大牛nlohmann写的&#xff0c;该版本的json有以下特点&#xff1a; 1.直观的语法。 2.整个代码由一个…

QT 创建插件 CTK开发(三)

CTK 为支持生物医学图像计算的公共开发包,其全称为 Common Toolkit。为医学成像提供一组统一的基本功能;促进代码和数据的交互及结合;避免重复开发;在工具包(医学成像)范围内不断扩展到新任务,而不会增加现有任务的负担;整合并适应成功的解决方案。 本专栏文章较为全面…

DP4056国产兼容替代LTC40561A锂离子电池充电芯片

目录 锂电池 VS 锂离子电池DP4056简介DP4056芯片特性 锂电池 VS 锂离子电池 锂电池是以锂金属或锂合金为正极材料&#xff0c;使用非水电解质溶液的电池。锂电池与锂离子电池不一样的是&#xff0c;前者是一次电池&#xff0c;后者是充电电池。锂离子电池工作原理就是依靠锂离…

(大数据开发随笔6)Hadoop 3.3.x分布式环境部署——本地模式

本地模式 材料准备 Linux虚拟机-CentOS7hadoop-3.3.1.tar.gz Index of /hadoop/common (apache.org)jdk-8u321-linux-x64.tar.gz Java Archive | Oracle Centos7虚拟机部署 准备材料&#xff1a; VMware17CentOS-7-x86_64-Minimal-2009.iso centos-7-isos-x86_64安装包下载…

2022国赛34:路由器之间ISIS协议配置

大赛试题内容: 5.RT1以太链路、RT2以太链路之间运行ISIS协议,进程10,分别实现loopback3 之间ipv4互通和ipv6互通。RT1、RT2的NET分别为10.0000.0000.0001.00、10.0000.0000.0002.00,路由器类型是Level-2,接口网络类型为点到点。配置域md5认证和接口md5认证,密码均为Key…

企业如何从0到1落地BI项目

企业需要数据整合、分析展现及应用的完整数据平台方案。为了满足集团化BI建设需求&#xff0c;企业决策层需要基于全局数据进行分析&#xff0c;需要提供数据整合、存储、计算到数据应用的端到端数据平台。 商业智能BI - 派可数据BI可视化分析平台 BI的实践落地需要全生命周期…

[Python基础] 序列(列表/元组)和字典的操作详解

文章目录 序列概念序列列表列表的创建和下标访问创建下标 列表的切片操作列表的遍历列表的插入操作列表的查找和删除列表的拼接 元组元组的相关操作 字典概念字典的创建查找字典中的key&#xff0c;value字典的增删改字典的遍历 序列概念 包含若干个元素, 元素有序排列, 可以通…

APIs -- DOM节点操作

1. 日期对象 日期对象&#xff1a;用来表示时间的对象 作用&#xff1a;可以得到当前系统时间 1.1 实例化 在代码中发现了new关键字时&#xff0c;一般将这个操作称为实例化 创建一个时间对象并获取时间&#xff1a;const date new Date(); // 实例化 new// 1.得到当前时…

React语法(N)

文章目录 React简介概述官网特点生态 react学习的说明新的官网全力投入现代React与Hooks React脚手架create-react-app官网创建和启动项目项目结构sass支持 Vite创建和启动项目项目结构常见配置 虚拟DOM什么是虚拟DOM虚拟DOM优缺点优点&#xff1a;缺点&#xff1a; 虚拟DOM实现…

CTF之命令执行常见绕过

命令执行常见绕过 1.空格代替 当我们执行系统命令时&#xff0c;不免会遇到空格&#xff0c;如cat flag.txt&#xff0c;当空格被程序过滤时&#xff0c;便需要利用以下字符尝试代替绕过&#xff1a; < ${IFS} $IFS$9 %09测试如下&#xff1a; $IFS 在 linux 下表示分隔…