使用shell进行数据千分、万分 小数截取

2023-10-22 21:20

本文主要是介绍使用shell进行数据千分、万分 小数截取,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

当我们对位数比较长的数字进行展示的时候,我们通常想对其进行千分展示。作为中国人,或许更乐意使用万分法。然后针对小数,如果位数过多最好也能够自定义截取。

文章目录

  • 前言
  • 一、sed的两种非常规语法介绍
    • 1. 匹配组
    • 2. 循环
  • 二. 数值的千分、万分 ...小数位处理
    • 1. 整数处理
    • 2. 小数处理
    • 3. 使用perl处理 [原文链接](https://blog.51cto.com/coders/2071768)


前言

使用shell实现数字的千分、万分和小数的截取


一、sed的两种非常规语法介绍

1. 匹配组

实操发现书写正则的时候必须对(){}进行转义,为便于理解,这里会给出转义前后的2个版本。

# 未转义版:sed 's/([a-z]*)([0-9]*)(.*)/\2/g' $(小写字母)(数字)(其他)
$ echo aaa111bbb222 | sed 's/\([a-z]*\)\([0-9]*\)\(.*\)/\2/g'
111
$ echo aaa111bbb222 | sed 's/\([a-z]*\)\([0-9]*\)\(.*\)/\1\3/g'
aaabbb222
# 此正则的含义为依次匹配连续字母、连续数字和任意字符,每个()作为一个匹配组,依次与后面的\1、\2、\3...对应
# 可单独取出匹配组如\1;取出多个匹配组\1\3或者\3\2;取出时可加入其他字符hello\1world\3。

2. 循环

# 将下列字符串变成abac
$ echo aaaaaaabaaac | sed 's/a*b/ab/g;s/a*c/ac/g'
abac
# 这里我们尝试使用循环的方式实现
$ echo aaaaaaabaaac | sed 's/aa/a/g'
aaaabaac
# 将表达式使用 :a; ;ta包裹,即表示循环执行中间的expr
# echo aaaaaaabaaac | sed ':a;s/aa/a/g;ta'
abac

二. 数值的千分、万分 …小数位处理

1. 整数处理

# 未转义版:sed 's/([0-9]{1,})([0-9]{3})/\1,\2/g' 
# 第1个()表示匹配开头1位以上的数字
# 第2个()表示匹配几个数字 3表示千分,4表示万分,以此类推 ...
$ echo 12345678901234567890 | sed ':a;s/\([0-9]\{1,\}\)\([0-9]\{3\}\)/\1,\2/g;ta'
12,345,678,901,234,567,890
$ echo 12345678901234567890 | sed ':a;s/\([0-9]\{1,\}\)\([0-9]\{4\}\)/\1,\2/g;ta'
1234,5678,9012,3456,7890
$ echo 12345678901234567890 | sed ':a;s/\([0-9]\{1,\}\)\([0-9]\{6\}\)/\1,\2/g;ta'
12,345678,901234,567890

2. 小数处理

# 未转义版:sed ':a;s/([0-9]{1,})([0-9]{4})(.[0-9]{3})*([0-9]*)/\1,\2\3/g;ta'
# 第1和2个()含义同上
# 第3个()表示匹配的小数位数 可自由指定
# 第4个()表示被截取小数的剩余部分
$ echo 1234567890.1234567890 |sed ':a;s/\([0-9]\{1,\}\)\([0-9]\{4\}\)\(\.[0-9]\{3\}\)*\([0-9]*\)/\1,\2\3/g;ta'
12,3456,7890.123# 如果小数保留的位数大于整数部分切分的位数,小数部分也会被格式化
$ echo 1234567890.1234567890 |sed ':a;s/\([0-9]\{1,\}\)\([0-9]\{3\}\)\(\.[0-9]\{5\}\)*\([0-9]*\)/\1,\2\3/g;ta'
1,234,567,890.12,345
# 解决方法:在第1个()前加^
$ echo 1234567890.1234567890 |sed ':a;s/\(^[0-9]\{1,\}\)\([0-9]\{3\}\)\(\.[0-9]\{5\}\)*\([0-9]*\)/\1,\2\3/g;ta'
1,234,567,890.12345# 如果遇到负数 在上述基础上^的后面增加-*即可
$ echo -1234567890.1234567890 |sed ':a;s/\(^-*[0-9]\{1,\}\)\([0-9]\{3\}\)\(\.[0-9]\{5\}\)*\([0-9]*\)/\1,\2\3/g;ta'
-1,234,567,890.12345

shell数据处理

3. 使用perl处理 原文链接

也存在将小数部分分隔的问题,暂对perl不是很了解,后续解决~也期待大佬能在评论区给出答案

$ echo '1234567890' | perl -pe 's/(?<=\d)(?=(\d{3})+\b)/,/g'
1,234,567,890
$ echo '1234567890.123456' | perl -pe 's/(?<=\d)(?=(\d{4})+\b)/,/g'
12,3456,7890.12,3456

这篇关于使用shell进行数据千分、万分 小数截取的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/263633

相关文章

shell脚本批量导出redis key-value方式

《shell脚本批量导出rediskey-value方式》为避免keys全量扫描导致Redis卡顿,可先通过dump.rdb备份文件在本地恢复,再使用scan命令渐进导出key-value,通过CN... 目录1 背景2 详细步骤2.1 本地docker启动Redis2.2 shell批量导出脚本3 附录总

批量导入txt数据到的redis过程

《批量导入txt数据到的redis过程》用户通过将Redis命令逐行写入txt文件,利用管道模式运行客户端,成功执行批量删除以Product*匹配的Key操作,提高了数据清理效率... 目录批量导入txt数据到Redisjs把redis命令按一条 一行写到txt中管道命令运行redis客户端成功了批量删除k

Java使用Thumbnailator库实现图片处理与压缩功能

《Java使用Thumbnailator库实现图片处理与压缩功能》Thumbnailator是高性能Java图像处理库,支持缩放、旋转、水印添加、裁剪及格式转换,提供易用API和性能优化,适合Web应... 目录1. 图片处理库Thumbnailator介绍2. 基本和指定大小图片缩放功能2.1 图片缩放的

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

MySQL中EXISTS与IN用法使用与对比分析

《MySQL中EXISTS与IN用法使用与对比分析》在MySQL中,EXISTS和IN都用于子查询中根据另一个查询的结果来过滤主查询的记录,本文将基于工作原理、效率和应用场景进行全面对比... 目录一、基本用法详解1. IN 运算符2. EXISTS 运算符二、EXISTS 与 IN 的选择策略三、性能对比

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

使用Python构建智能BAT文件生成器的完美解决方案

《使用Python构建智能BAT文件生成器的完美解决方案》这篇文章主要为大家详细介绍了如何使用wxPython构建一个智能的BAT文件生成器,它不仅能够为Python脚本生成启动脚本,还提供了完整的文... 目录引言运行效果图项目背景与需求分析核心需求技术选型核心功能实现1. 数据库设计2. 界面布局设计3

使用IDEA部署Docker应用指南分享

《使用IDEA部署Docker应用指南分享》本文介绍了使用IDEA部署Docker应用的四步流程:创建Dockerfile、配置IDEADocker连接、设置运行调试环境、构建运行镜像,并强调需准备本... 目录一、创建 dockerfile 配置文件二、配置 IDEA 的 Docker 连接三、配置 Do

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

Android Paging 分页加载库使用实践

《AndroidPaging分页加载库使用实践》AndroidPaging库是Jetpack组件的一部分,它提供了一套完整的解决方案来处理大型数据集的分页加载,本文将深入探讨Paging库... 目录前言一、Paging 库概述二、Paging 3 核心组件1. PagingSource2. Pager3.