实现一个formatStr
时间: 2024-01-17 20:50:30 浏览: 64
()函数,将字符串中的大写字母转换为小写字母,并将空格替换为下划线"_"。
好的,根据您的要求,我可以为您编写一个Python的formatStr()函数,代码如下:
```
def formatStr(input_str):
converted_str = input_str.lower().replace(" ", "_")
return converted_str
```
这个函数可以将输入的字符串中的大写字母转换为小写字母,并将空格替换为下划线"_"。
例如,如果您调用`formatStr("Hello World")`,就会返回字符串"hello_world"。
希望这个函数能够满足您的要求。
相关问题
用C语言实现一个formatStr
,将一个字符串中的多个空格转化成一个空格。
答案如下:
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main()
{
char str[100];
printf("请输入字符串:\n");
fgets(str,sizeof(str),stdin); // 读取输入的字符串
int len = strlen(str); // 获取字符串长度
int cnt = 0; // 记录连续空格的个数
for(int i = 0;i < len;i++)
{
if(str[i] == ' ') // 如果遇到空格
{
cnt++; // 连续空格个数加1
if(cnt > 1) // 如果是多个连续空格
{
// 去掉该空格
for(int j = i + 1;j < len - cnt + 1;j++)
{
str[j-1] = str[j];
}
len--; // 字符串长度减1
i--; // 下标也减1,以便继续判断当前位置的字符
}
}
else // 如果不是空格
{
cnt = 0; // 连续空格个数清零
}
}
printf("格式化后的字符串为:%s",str);
return 0;
}
```
上述代码中,我们读入字符串后,依次遍历字符串中的每个字符,如果遇到空格,则判断是否是多个连续空格,如果是,则去掉该空格,否则继续寻找下一个字符。最后输出格式化后的字符串。
注意事项:本程序中使用了fgets函数读取输入的字符串,在编写该程序时需要确保输入的字符串长度不超过数组str的长度。同时,我们应该避免在字符串中间使用连续的空格,否则可能会影响格式化的效果。
#ifndef MYSPDLOG_H #define MYSPDLOG_H #include <fstream> #include <iostream> #define SPDLOG_HEADER_ONLY #define SPDLOG_ACTIVE_LEVEL SPDLOG_LEVEL_DEBUG #include "spdlog/spdlog.h" #include "spdlog/logger.h" #include "spdlog/sinks/basic_file_sink.h" #include "spdlog/sinks/rotating_file_sink.h" #include "spdlog/sinks/stdout_color_sinks.h" #include "spdlog/sinks/daily_file_sink.h" class MySpdlog { public: static MySpdlog*getInstace() { static MySpdlog MySpdlogStatic; return &MySpdlogStatic; } int init() { std::string formatStr="%Y-%m-%dT%H:%M:%S.%e[%l][%s:%#][%!]%v"; // auto myLogger1 = std::make_shared<spdlog::sinks::rotating_file_sink_mt>("spdlog", "logs/myspdlog.log", 1024 * 1024 * 10, 10); // auto myLogger1 = std::make_shared<spdlog::sinks::daily_file_sink>("spdlog", "logs/log.txt", 0, 0); auto myLogger1 = spdlog::daily_logger_mt("spdlog", "logs/log.txt", 0, 0); // myLogger1 = spdlog::rotating_logger_mt("spdlog", "logs/myspdlog.log", 1024 * 1024 * 10, 10); spdlog::set_default_logger(myLogger1); myLogger1->set_level(spdlog::level::debug); myLogger1->set_pattern(formatStr); myLogger2 = spdlog::stdout_color_mt("baseLogger2"); spdlog::set_default_logger(myLogger2); myLogger2->set_level(spdlog::level::debug); myLogger2->set_pattern(formatStr); return 0; } void uninit() { } std::shared_ptr<spdlog::logger> myLogger1; std::shared_ptr<spdlog::logger> myLogger2; private: MySpdlog() {} ~MySpdlog() {} }; #define SPLOG_INIT() MySpdlog::getInstace()->init() #define SPLOG_UNINIT() MySpdlog::getInstace()->uninit() #define SPLOG_DEBUG(...) do {SPDLOG_LOGGER_DEBUG(MySpdlog::getInstace()->myLogger1, __VA_ARGS__);\ SPDLOG_LOGGER_DEBUG(MySpdlog::getInstace()->myLogger2, __VA_ARGS__);}while(0) #define SPLOG_INFO(...) do {SPDLOG_LOGGER_INFO(MySpdlog::getInstace()->myLogger1, __VA_ARGS__);\ SPDLOG_LOGGER_INFO(MySpdlog::getInstace()->myLogger2, __VA_ARGS__);}while(0) #define SPLOG_ERROR(...) do {SPDLOG_LOGGER_ERROR(MySpdlog::getInstace()->myLogger1, __VA_ARGS__);\ SPDLOG_LOGGER_ERROR(MySpdlog::getInstace()->myLogger2, __VA_ARGS__);}while(0) #define SPDLOG_CLRAR(a) do{std::fstream fout((a),std::ios::out|std::ios::trunc);fout.close();}while(0); #endif // MYSPDLOG_H运行之后调用SPLOG_INFO时报错
根据您提供的代码,我看到您定义了一个名为`SPLOG_INFO`的宏,其实现方式为:
```
#define SPLOG_INFO(...) do {SPDLOG_LOGGER_INFO(MySpdlog::getInstace()->myLogger1, __VA_ARGS__);\
SPDLOG_LOGGER_INFO(MySpdlog::getInstace()->myLogger2, __VA_ARGS__);}while(0)
```
这个宏展开后会调用`SPDLOG_LOGGER_INFO`来输出日志信息,而`SPDLOG_LOGGER_INFO`需要传入一个有效的logger对象作为第一个参数。在您的代码中,您定义了一个名为`myLogger1`的logger对象,但是您没有在宏中使用它,而是在`MySpdlog`类中以成员变量的形式定义。因此,当您调用`SPLOG_INFO`时,会找不到有效的logger对象,从而导致编译错误。
要解决这个问题,您可以将`myLogger1`和`myLogger2`定义为静态成员变量,并在`MySpdlog`类外初始化它们。然后,在宏中使用这两个静态成员变量。
例如,您可以将`MySpdlog`类的定义改为:
```
class MySpdlog {
public:
static MySpdlog*getInstace()
{
static MySpdlog MySpdlogStatic;
return &MySpdlogStatic;
}
int init()
{
std::string formatStr="%Y-%m-%dT%H:%M:%S.%e[%l][%s:%#][%!]%v";
auto myLogger1 = spdlog::daily_logger_mt("spdlog", "logs/log.txt", 0, 0);
spdlog::set_default_logger(myLogger1);
myLogger1->set_level(spdlog::level::debug);
myLogger1->set_pattern(formatStr);
auto myLogger2 = spdlog::stdout_color_mt("baseLogger2");
spdlog::set_default_logger(myLogger2);
myLogger2->set_level(spdlog::level::debug);
myLogger2->set_pattern(formatStr);
return 0;
}
void uninit()
{
}
static std::shared_ptr<spdlog::logger> myLogger1;
static std::shared_ptr<spdlog::logger> myLogger2;
private:
MySpdlog() {}
~MySpdlog() {}
};
std::shared_ptr<spdlog::logger> MySpdlog::myLogger1;
std::shared_ptr<spdlog::logger> MySpdlog::myLogger2;
```
然后,您可以在代码的其他地方使用这两个静态成员变量。例如,在`SPLOG_INFO`中,您可以这样使用:
```
#define SPLOG_INFO(...) \
do { \
SPDLOG_LOGGER_INFO(MySpdlog::myLogger1, __VA_ARGS__); \
SPDLOG_LOGGER_INFO(MySpdlog::myLogger2, __VA_ARGS__); \
} while(0)
```
这样,当您调用`SPLOG_INFO`时,就会使用正确的logger对象输出日志信息,从而避免编译错误。
阅读全文