【Linux】【开发】使用sed命令遇到的乱码问题

  • 🐚作者简介:花神庙码农(专注于Linux、WLAN、TCP/IP、Python等技术方向)
  • 🐳博客主页:花神庙码农 ,地址:https://blog.csdn.net/qxhgd
  • 🌐系列专栏:Linux技术
  • 📰如觉得博主文章写的不错或对你有所帮助的话,还望大家三连支持一下呀!!! 👉关注✨、点赞👍、收藏📂、评论。
  • 如需转载请参考转载须知!!

使用sed命令遇到的乱码问题

问题描述

  • 在某个配置文件card_config.h中,某行有如下配置:
c 复制代码
#define CARD_INTERFACE_MAX     4          //单网卡接口个数的最大值
  • 由于需要通过编译命令来动态修改这个值(比如,将最大数目扩展到8),因此,在文件中增加如下命令:
bash 复制代码
@sed -i -e  "s/.*#define CARD_INTERFACE_MAX.*/#define CARD_INTERFACE_MAX 8/" $(XXX_PATH)/config/card_config.h
  • 期望替换之后,文件对应行的内容为:
bash 复制代码
#define CARD_INTERFACE_MAX     8
  • 测试发现,编译时会出问题。

问题分析

  • 经确认,发现编译之前,card_config.h文件中的对应行中有乱码。编译之后,该文件中也有乱码。
  • 经过vim命令set fileencoding确认:
bash 复制代码
sef  fileencoding=latin1                                                                                     18,1           1%

问题解决

  • 怀疑和中文注释有关,将中文注释删除,测试正常;
  • 将中文注释或替换为英文注释,测试正常;
  • 查看card_config.h文件的编码格式,发现非UTF-8,将其强制修改为UTF-8后,测试也正常。
bash 复制代码
set fileencodings=utf-8 

从网上查的资料中,有如下信息:

注意,在使用sed替换中文时,需要确保你的终端使用UTF-8编码,并且你的文本文件也使用UTF-8编码。否则,sed可能无法正确地识别和替换中文字符串。

vim相关命令汇总

  • 修改文件编码格式
bash 复制代码
:set fileencoding=utf-8
  • 查看文件编码格式
bash 复制代码
:set fileencoding

小结

  • 开发中,尽量不要使用中文注释,容易出问题;
  • 文件的编码格式尽量使用UTF-8。

如本文对你有些许帮助,欢迎大佬加关注、评论、点赞,有关必回关

相关推荐
fy zs4 分钟前
网络基础概念
linux·网络·c++
学习3人组10 分钟前
CentOS 系统下 ModelScope 模型下载的默认目录
linux·python·centos
Java陈序员36 分钟前
运维必备!一款全平台可用的服务器管理利器!
linux·react.js·docker
oMcLin37 分钟前
如何在Oracle Linux 8.5上配置并优化Oracle RAC集群,确保企业级数据库的高可用性与负载均衡?
linux·数据库·oracle
威桑37 分钟前
交叉编译过程中的踩坑与收获
linux·c++·arm·交叉编译
HIT_Weston43 分钟前
90、【Ubuntu】【Hugo】搭建私人博客:侧边导航栏(四)
linux·运维·ubuntu
回忆是昨天里的海1 小时前
dockerfile-镜像分层机制
linux·运维·服务器
chen_mangoo1 小时前
Rockchip debian预置安装deb包
linux·驱动开发·嵌入式硬件
雪风飞舞1 小时前
conda 常用命令
linux·windows·conda
用户74712201169831 小时前
linux最小版本编译-草稿(有空再来修改下)
linux