YAML-CPP
yaml作为一种便捷的文件格式,通过c++进行操作时,可以利用yaml-cpp进行。
一,yaml-cpp的安装
下载源码
git clone https://github.com/jbeder/yaml-cpp.git
编译安装
mkdir build
cd build
cmake -DBUILD_SHARED_LIBS=ON .. # ON 设置生成共享库
sudo make install
验证
pkg-config --modversion yaml-cpp
使用
YAML::Node node1 = YAML::LoadFile("config.yaml"); // 加载文件
YAML::Node node2 = YAML::Load("[1,2,3]"); // 加载数组
cout << node1[0].as<string>() << endl;
cout << node2[0].as<int>() << endl; // 输出元素
更多API参考yaml-cpp docs。
示例:
a、CMakeLists.txt
cmake_minimum_required(VERSION 2.8)
project(yaml_test)
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++11")
link_directories(/home/jonty/Softwares/yaml-cpp/build)
include_directories(/home/jonty/Softwares/yaml-cpp/include/yaml-cpp)
add_executable(test main.cpp)
target_link_libraries(test yaml-cpp)
b、main.cpp
#include <iostream>
#include "yaml.h"
using namespace std;
int main()
{
YAML::Node node = YAML::Load("[22,3,4,4]");
cout << node[0] << endl;
YAML::Node node2 = YAML::LoadFile("../config.yaml");
cout << node2["ttt"] << endl;
return 0;
}
编译运行
mkdir build
cd build
cmake ..
make
./test
参考教程https://github.com/jbeder/yaml-cpp/wiki/Tutorial
编译也可以采用g++ test.cpp /usr/local/lib/libyaml-cpp.a -std=c++11
源码编译yaml-cpp
git clone https://github.com/jbeder/yaml-cpp.git
cd yaml-cpp # 进入克隆的文件夹
mkdir build
cd build
cmake ..
make
make install
可参考https://blog.csdn.net/Fourier_Legend/article/details/82798297
记得在CMakeLists.txt中加入
link_directories(/usr/local/lib)
include_directories(/usr/local/include/yaml-cpp)
以及在链接库target_link_libraries时,加上yaml-cpp。
void write_robot_status_to_yaml(string path, const string &filename,
double x, double y, double th)
{
//dir_file_exists(path, true);
dir_file_exists(path, false, true, filename.c_str());
std::ofstream yaml_file(path + filename, std::ios::out | std::ios::binary);
{
YAML::Emitter out(yaml_file);
out << YAML::BeginMap;
// TODO(whess): Use basename only?
out << YAML::Key << "x";
out << YAML::Value << x;
out << YAML::Key << "y";
out << YAML::Value << y;
out << YAML::Key << "th";
out << YAML::Value << th;
out << YAML::EndMap;
} yaml_file.close();
}
bool read_robot_status_from_yaml(string file_path, const string &file_name, double &x,
double &y, double &th)
{
if (!dir_file_exists(file_path, false, true, file_name.c_str()))
return false;
std::ifstream yaml_file(file_path + file_name, std::ios::out | std::ios::binary);
{
YAML::Node doc = YAML::Load(yaml_file); doc["x"] >> x;
doc["y"] >> y;
doc["th"] >> th;
}
yaml_file.close(); return true;
}
/*
* @brief 创建文件夹
*/
bool dir_file_exists(string dir, bool mkdir_flag, bool touchfile_flag, string filename)
{
char des_dir[];
str_2_char(dir, des_dir);
int state = access(des_dir, R_OK | W_OK);//#include<unistd.h>
if(state == )
{
ROS_INFO("state == 0");
return true;
}
else if(mkdir_flag)
{
dir = "mkdir " + dir;
str_2_char(dir, des_dir);
if(system(des_dir))
{
printf("generate dir %s successfully.",dir.c_str());
ROS_INFO("generate dir %s successfully.",dir.c_str());
//Basic_Info("generate dir {} successfully.",dir.c_str());
}
else
{
printf("generate dir %s fail.",dir.c_str());
ROS_INFO("generate dir %s fail.",dir.c_str());
//Basic_Info("generate dir {} fail.",dir.c_str());
}
return true;
}
else if(touchfile_flag)
{
dir = "touch " + dir + "/" + filename;
ROS_INFO("dir is %s", dir.c_str());
str_2_char(dir, des_dir);
if(system(des_dir))
{
printf("generate filename %s successfully.",dir.c_str());
ROS_INFO("generate filename %s successfully.",dir.c_str());
//Basic_Info("generate filename {} successfully.",dir.c_str());
}
else
{
printf("generate filename %s fail.",dir.c_str());
ROS_INFO("generate filename %s fail.",dir.c_str());
//Basic_Info("generate filename {} fail.",dir.c_str());
}
return true;
}
return false;
}
template <typename T>
void operator>>(const YAML::Node& node, T& i); template <typename T>
void operator>>(const YAML::Node& node, T& i) {
i = node.as<T>();
};
写个模板类加载参数
template<typename T>
T getParam(const string& name,const T& defaultValue) //This name must be namespace+parameter_name
{
T v;
if(ros::param::get(name,v)) //get parameter by name depend on ROS.
{
ROS_INFO_STREAM("Found parameter: "<<name<<",\tvalue: "<<v);
return v;
}
else
ROS_WARN_STREAM("Cannot find value for parameter: "<<name<<",\tassigning default: "<<defaultValue);
return defaultValue; //if the parameter haven't been set,it's value will return defaultValue.
}
在ROS系统中,参数读写一般通过xml或者yaml格式的文件,其中yaml用得比较多。这是一种可读性高,轻量级的标记语言,简单好用。
对于yaml文件,ros中用的较早版本的yaml-cpp库,最新的可在github上下载,并按照readme中所述的方法编译安装。
特别留意的是,如果需要生成共享库,cmake的时候后面一定要加上 -DBUILD_SHARED_LIBS=ON 这句话。
有了yaml库,在CMakeLists.txt中加入,
link_directories(/usr/local/lib)
include_directories(/usr/local/include/yaml-cpp)
最后别忘了在链接库target_link_libraries时,加上yaml-cpp。
关于库的使用,github上有一些简单的tutorial教程。
以下是简单的yaml文件读写操作示例。
#include <ros/ros.h>
#include <yaml-cpp/yaml.h>
#include <iostream>
#include <fstream> int main(int argc, char **argv)
{
std::string fin = "/home/user/param/param.yaml"; //yaml文件所在的路径
YAML::Node yamlConfig = YAML::LoadFile(fin);
int int_param = yamlConfig["int_param"].as<int>();
std::cout << " node size: " << yamlConfig.size() << std::endl;
std::cout << yamlConfig["bool_param"].as<bool>() << "\n";
yamlConfig["bool_param"] = !yamlConfig["bool_param"].as<bool>();
yamlConfig["str_param"] = "test";
std::ofstream file;
file.open(fin);
file.flush();
file << yamlConfig;
file.close(); return ;
}
其中,yaml文件里的内容为:
bool_param: true
int_param: 2
double_param: 0.5
str_param: "123"
也可采用Emit来生成yaml文件,代码如下:
#include <ros/ros.h>
#include <yaml-cpp/yaml.h>
#include <iostream>
#include <fstream> int main(int argc, char **argv)
{
std::ofstream fout("/home/user/param/param.yaml");
YAML::Emitter out(fout);
out << YAML::BeginMap;
out << YAML::Key << "int_param";
out << YAML::Value << ;
out << YAML::Key << "double_param";
out << YAML::Value << 0.5;
out << YAML::Key << "bool_param";
out << YAML::Value << false;
out << YAML::Comment("bool parameter");
out << YAML::Key << "str_param";
out << YAML::Value << "test";
out << YAML::EndMap; return ;
}
yml文件的其他操作可参见博文《.yaml参数文件的编写和使用》,
其综合运用的案例可参见博文:ros-opencv-qt-yaml综合运用之滤波。
YAML-CPP的更多相关文章
- c++ 解析yaml文件
一直用c++操作ini做配置文件,想换成yaml,在全球最大的同性交友网站github上搜索,看有没有开源的库,功夫不负有心人,找到了yaml-cpp,用他解析了一个yaml的例子非常好使,分享一下如 ...
- C#与yaml解析
YAML 官方网站称 YAML 是"一种所有编程语言可用的友好的数据序列化标准".YAML Ain't Markup Language,和GNU一样,YAML是一个递归着说&quo ...
- 使用“Cocos引擎”创建的cpp工程如何在VS中调试Cocos2d-x源码
前段时间Cocos2d-x更新了一个Cocos引擎,这是一个集合源码,IDE,Studio这一家老小的整合包,我们可以使用这个Cocos引擎来创建我们的项目. 在Cocos2d-x被整合到Cocos引 ...
- SpringBoot中yaml配置对象
转载请在页首注明作者与出处 一:前言 YAML可以代替传统的xx.properties文件,但是它支持声明map,数组,list,字符串,boolean值,数值,NULL,日期,基本满足开发过程中的所 ...
- Json CPP 中文支持与入门示例
在每一个Json Cpp自带*.cpp文件头加上: #include "stdafx.h" 将Json Cpp对自带的头文件的引用修改为单引号方式,例如json_reader.cp ...
- cpp 调用python
在用cpp调用python时, 出现致命错误: no module named site , 原因解释器在搜索路径下没有找到python库.可以在调用Py_Initialize前,调用 Py_Se ...
- nginx+fastcgi+c/cpp
参考:http://github.tiankonguse.com/blog/2015/01/19/cgi-nginx-three/ 跟着做了一遍,然后根据记忆写的,不清楚有没错漏步骤,希望多多评论多多 ...
- APM程序分析-ArduCopter.cpp
该文件是APM的主文件. #define SCHED_TASK(func, rate_hz, max_time_micros) SCHED_TASK_CLASS(Copter, &copter ...
- APM程序分析-AC_WPNav.cpp
APM程序分析 主程序在ArduCopter.cpp的loop()函数. /// advance_wp_target_along_track - move target location along ...
- Dev Cpp 输出中文字符问题
最近 c++ 上机作业,vc++6.0 挂了没法用,只好用 Dev Cpp 先顶替一下,然而在遇到输出中文字符的时候出现了乱码的情况,但这种情况又非常诡异.于是简单了解了一下写成此博客. [写在前面] ...
随机推荐
- ORM版学员管理系统 2
学生信息管理 展示学生信息 URL部分 url(r'^student_list/', app01_views.student_list, name="student_list"), ...
- python基础1.0
1. python简介:解释性语言 安装python,注意路径加入path python的解释器,cpython,Python的解释器很多,但使用最广泛的还是CPython.如果要和Java或.Net ...
- AS3获得当前文件的文件名
//当前文件的完整路径var fileUrl:String = this.loaderInfo.url;//查找路径的最后一个"/"var flag:int = fileUrl.l ...
- Redis系列十:缓存雪崩、缓存穿透、缓存预热、缓存更新、缓存降级
一.缓存雪崩 缓存雪崩我们可以简单的理解为:由于原有缓存失效,新缓存未到期间(例如:我们设置缓存时采用了相同的过期时间,在同一时刻出现大面积的缓存过期),所有原本应该访问缓存的请求都去查询数据库了,而 ...
- oracle数据库用户删除及表空间删除
以system用户登录,查找需要删除的用户: --查找用户 select * from dba_users; --查找工作空间的路径select * from dba_data_files; --删 ...
- computer browser服务无法启动 错误1068 依存服务或组无法启动
两台电脑电脑之间传送大文件,发现局域网内共享文件,需要设置文件夹共享,需要开启 Computer Browser服务,而Computer Browser服务项的依存服务项是server服务和works ...
- 初学python笔记----字符串
---恢复内容开始--- 1.在python中,用引号括起来的都是字符串,引号可以是单引号,也可以是双引号 2.修改字符串的大小写 3.字符串拼接用“+” 4.制表符("\t"), ...
- 大数据架构工具hadoop
Hadoop是一个开源框架,它允许在整个集群使用简单编程模型计算机的分布式环境存储并处理大数据.它的目的是从单一的服务器到上千台机器的扩展,每一个台机都可以提供本地计算和存储. “90%的世界数据在过 ...
- MySQL 5.7自定义安装图文详解
本文教程为大家分享了mysql5.7安装配置方法,供大家参考,具体内容如下 mysql-installer-community-5.7.9.1各版本相关说明: mysql-installer-web- ...
- 开源虚拟化KVM(三)管理虚拟网络
六,管理虚拟网络 [x] Linux网桥基本概念 [x] qemu-kvm支持的网络 [x] 向虚拟机添加虚拟网络连接 [x] 基于NAT的虚拟网络 [x] 基于网桥的虚拟网络 [x] 用户自定义的隔 ...