html 显示不可见字符,真实用! 一键清除不可见字符

原标题:真实用! 一键清除不可见字符

在EXCEL数据处理中,我们常常会受到不可见字符的干扰,就比如下面这个例子:

3ed71aa51d018ca84d5a139a40cf4d07.png

左看右看,公式也并没写错呀,可是,东坡君你肿么了?

此时,作为一个冷静的侠客,手要稳,心要定,首先就要想到,A2和D1这俩格子内容是不一样的!哪里不一样呢?

可以先用len函数看看长度,果然,D1是2字符,A2是3字符:

fa09fe031fae1b71b8a0408655c2515e.png

可是当我们从编辑栏仔细查看A2内容时,却是看不到“莫须有”的第三个字符在哪。

15c7790d0c8e30ce56943ce12cdc5ca4.png

此时,作为一个有经验的侠客,就会使用left、right函数取出A2的首个、末尾字符,再用code函数看看,它是个什么。

果然,right(A2,1)的结果是无法看见的,且其code值是9:

5dec90b9930655c1d7f40c62da7e3b41.png

于是我们知道了,A2中多出来的那个字符是char(9),即制表符,这是很多从网页中粘贴出来的数据,常常会“携带”的多余字符。

如此例的情况,我们可以用left(A2,len(A2)-1)的公式方法,去掉这一列普遍携带的多余字符。

然而,其实实际中遇到的不可见字符并非总在首尾之类有规律的位置,也不一定只有一种,常见的,就可能有以下的类型(Char是ASCII码表值,EXCEL中可以用char公式查看):

Char(1),空字符NULL

Char(9),制表符

Char(10),换行符

Char(13),回车符

Char(32),空格

Char(160),这是HTML中的一种空格,复制到EXCEL中也看不见

这么多种不可见字符怎么处理掉呢?

虽然我们知道TRIM函数可以用来去掉多余空格(且留下英文单词中间该有的空格),但对其他情况可就不行了。

不过一定要用公式解决的话,也并非不可,因为,有一个叠加SUBSTITUTE的“可怕”方法:

=SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(A2,CHAR(1),""),CHAR(9),""),CHAR(10),""),CHAR(13),""),CHAR(32),"")

这就叠了5个SUBSTITUTE,用来去掉单元格中的5种不可见字符~~

是不是非常无语?

于是呢,我们可以用加载VBA的方式,添加这样一个自定义功能:

2b576857ae21d1c858bf2c3d425835ac.png

如需去掉不可见字符,只要选中区域,点击“删除不可见字符”按钮,即可完成:

05c53099fd1bb5562281f2ba25b5f936.png

代码是比较简单的,其实就是把6次叠加substitute换成了VBA函数replace来完成:

Sub 删除不可见字符()

'此代码的附加功能:若遇到带公式的格子,会先转换为不带公式的值,再去掉不可见字符。

'有个bug,所有处理过的区域都会变成文本格式

Dim rng As Range, i, j, k, leng As Integer

Dim r, c, s, ascma

Set rng = Selection

arr = rng

r = rng.Rows.Count

c = rng.Columns.Count

rng.Interior.ColorIndex = xlNone'设置区域背景为无色

rng.NumberFormatLocal = "@"'设置区域格式为文本

If r = 1 And c = 1 Then

arr = Replace(arr, ChrW(1), "")

arr = Replace(arr, ChrW(9), "")

arr = Replace(arr, ChrW(10), "")

arr = Replace(arr, ChrW(13), "")

arr = Replace(arr, ChrW(32), "")

arr = Replace(arr, ChrW(160), "")

Else

For i = 1 To r

For j = 1 To c'1、32是空格,9是制表符,10、13是换行符

arr(i, j) = Replace(arr(i, j), ChrW(1), "")

arr(i, j) = Replace(arr(i, j), ChrW(9), "")

arr(i, j) = Replace(arr(i, j), ChrW(10), "")

arr(i, j) = Replace(arr(i, j), ChrW(13), "")

arr(i, j) = Replace(arr(i, j), ChrW(32), "")

arr(i, j) = Replace(arr(i, j), ChrW(160), "")

Next

Next

End If

rng = arr

MsgBox "区域中的空格、制表符、换行符、char(160)都已删除!!!"

End Sub

如何将它们添加到功能区呢?很简单:

一、写入加载宏文件。

1, 新建一个EXCEL工作薄,打开代码页面(在“开发工具”中点击Visual Basic或按快捷键Alt+F11或右键任意工作表名-查看代码);

2, 在代码页面中插入模块,模块名可自己更改;

9c03ae36018131682cb07423d2645a27.png

3, 双击新建的模块,在右侧代码窗口贴入代码,关闭代码页面;

4, 点击文件-另存为,将文件存为“EXCEL加载宏”格式,即xlam格式(此格式有固定路径,无需选择路径);一般来说,这个文件路径是在:C盘用户用户名AppDataRoamingMicrosoftAddins,以后如需更新代码,可以在此找到。

5,关掉文件。

二、添加自定义功能区

1, 另外打开一个其他的EXCEL文档,点击文件-选项-自定义功能区-宏,在左侧找到添加的两个宏,并将它们添加到右侧的“自定义”区中(若无此区,可用新建选项卡-新建组),使用重命名,可以改变其图标。点击确定。

(在有的版本OFFICE中,“选项-自定义功能区-宏”的左侧不直接显示加载项,此时需要先从“选项-加载项”中选择“转到”先进性确定,才能完成上述操作)

8e56f6e3e443aaa9928c3c6b716d0fb8.png

2, 之后,在功能区的“自定义”选项之下,就有了所添加的按钮:

4d4f0b870f1d123a1f52dd30918ea478.png

——Hoa小熊猫

责任编辑:

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
#资源达人分享计划# 1. 支持PHP8 2. 支持HTTPS环境 3. 支持MySQL8+ 4. 修改PHPCMS目录为CMS 5. 验证码修改 6. 支持H5上传,移除Flash上传 7. 修改后台缩略图裁切图片,移除Flash裁切改为H5裁切 8. 后台附件上传修改为H5上传,会员头像上传修改为H5上传 9. 修改后台界面,修改后台登录界面、后台锁屏界面、后台内容界面 10. 修改前台界面 11. 修复已知BUG 12. 修复已知安全漏洞 13. 增加安装时自定义后台管理登录地址 14. 去掉PHPSSO模块、去掉Video及视频库相关、去掉Upgrade在线升级 15. 去除了已被废弃的视频模块和视频模型 16. 修复安装时DNS解析错误提示 17. 手机电脑同时生成Html 18. 安装文件不检查index.html 19. 安装完删除安装目录 20. 安装删除友情链接、广告数据 21. 添加开启附件分站状态 22. 整合UEditor编辑器 23. UEditor整合上传水印 24. UEditor上传储存数据 25. 附件选择框UI 26. 优化附件选择器界面 27. 添加讯飞关键词获取API、百度关键词获取API,原官方关键词接口已失效 28. 后台添加复制,可复制一条新的到任何栏目或站点 29. 添加头像字段 30. 修改头像,重新写入库 31. 添加组图模式,图片模式、文本模式 32. 百度编辑器上传视频播放器由embed改成video标签 33. 添加本地关键词获取API,原官方关键词接口已失效 34. 添加站点自定义字段、栏目自定义字段、单网页自定义字段 35. 添加一键导入微信文章字段 36. 添加Word导入编辑器字段 37. 增加编辑器可下载微信图片本地化功能 38. 编辑器远程下载图片时加入对尺寸的压缩处理 39. 后台登录密码传输改为加密模式 40. 添加生成静态页进度条 41. 编辑器添加本地图片自动上传 42. 升级为CK4.16.1编辑器 43. 无用文件清理 44. 修改生成缩略图函数thumb 45. 修改获取用户头像函数get_memberavatar 46. 修改原来上传类处理文件,删除原上传类处理文件,新增Upload上传类处理文件 47. 修改原来图片处理类文件 48. 修改IP库类处理文件 49. 新增二维码处理类文件 50. 新增Input类处理文件 51. 新增判断是否是移动端终端is_mobile函数 52. 新增二维码qrcode函数 53. 新增秒转化时间sec2time函数 54. 新增友好时间显示函数dr_fdate 55. 新增时间显示函数dr_date 56. 新增递归创建文件夹create_folder函数 57. 新增调用远程数据dr_catcher_data函数 58. 新增获取远程附件扩展名get_file_ext函数 59. 新增栏目面包屑导航dr_catpos函数 60. 新增手机栏目面包屑导航dr_mobile_catpos函数 61. 新增手机分页函数mobilepages 62. 新增重新日志记录函数log_message 63. 新增目录扫描dr_dir_map函数 64. 新增文件扫描dr_file_map函数 65. 新增数据返回统一格式dr_return_data函数 66. 新增格式化输出文件大小format_file_size函数 67. 新增附件信息get_attachment函数 68. 新增统一返回json格式并退出程序dr_json函数 69. 新增将数组转换为字符串dr_array2string函数 70. 新增将字符串转换为数组dr_string2array函数 71. 新增根据文件扩展名获取文件预览信息dr_file_preview_html函数 72. 新增IP转为实际地址ip2address函数 73. 新增当前IP实际地址ip_address_info函数 74. 新增清除HTML标记clearhtml函数 75. 新增提取关键字dr_get_keywords函数 76. 新增提取描述信息dr_get_description函数 77. 新增获取内容中的缩略图get_content_img函数 78. 新增HTML实体字符转换code2html函数 79. 新增判断存在于数组中dr_in_array函数 80. 新增字符长度dr_strlen函数 81. 新增将路径进行安全转换变量模式dr_safe_replace_path函数 82. 新增站点手机配置 83. 新增是否需要检查外部访问 84. 新增关联字段 85. 新增信息表格字段 86. 新增单文件上传字段 等等等………… 增加在线升级
1. 支持PHP8 2. 支持HTTPS环境 3. 支持MySQL8+ 4. 修改PHPCMS目录为CMS 5. 验证码修改 6. 支持H5上传,移除Flash上传 7. 修改后台缩略图裁切图片,移除Flash裁切改为H5裁切 8. 后台附件上传修改为H5上传,会员头像上传修改为H5上传 9. 修改后台界面,修改后台登录界面、后台锁屏界面、后台内容界面 10. 修改前台界面 11. 修复已知BUG 12. 修复已知安全漏洞 13. 增加安装时自定义后台管理登录地址 14. 去掉PHPSSO模块、去掉Video及视频库相关、去掉Upgrade在线升级 15. 去除了已被废弃的视频模块和视频模型 16. 修复安装时DNS解析错误提示 17. 手机电脑同时生成Html 18. 安装文件不检查index.html 19. 安装完删除安装目录 20. 安装删除友情链接、广告数据 21. 添加开启附件分站状态 22. 整合UEditor编辑器 23. UEditor整合上传水印 24. UEditor上传储存数据 25. 附件选择框UI 26. 优化附件选择器界面 27. 添加讯飞关键词获取API、百度关键词获取API,原官方关键词接口已失效 28. 后台添加复制,可复制一条新的到任何栏目或站点 29. 添加头像字段 30. 修改头像,重新写入库 31. 添加组图模式,图片模式、文本模式 32. 百度编辑器上传视频播放器由embed改成video标签 33. 添加本地关键词获取API,原官方关键词接口已失效 34. 添加站点自定义字段、栏目自定义字段、单网页自定义字段 35. 添加一键导入微信文章字段 36. 添加Word导入编辑器字段 37. 增加编辑器可下载微信图片本地化功能 38. 编辑器远程下载图片时加入对尺寸的压缩处理 39. 后台登录密码传输改为加密模式 40. 添加生成静态页进度条 41. 编辑器添加本地图片自动上传 42. 升级为CK4.16.1编辑器 43. 无用文件清理 44. 修改生成缩略图函数thumb 45. 修改获取用户头像函数get_memberavatar 46. 修改原来上传类处理文件,删除原上传类处理文件,新增Upload上传类处理文件 47. 修改原来图片处理类文件 48. 修改IP库类处理文件 49. 新增二维码处理类文件 50. 新增Input类处理文件 51. 新增判断是否是移动端终端is_mobile函数 52. 新增二维码qrcode函数 53. 新增秒转化时间sec2time函数 54. 新增友好时间显示函数dr_fdate 55. 新增时间显示函数dr_date 56. 新增递归创建文件夹create_folder函数 57. 新增调用远程数据dr_catcher_data函数 58. 新增获取远程附件扩展名get_file_ext函数 59. 新增栏目面包屑导航dr_catpos函数 60. 新增手机栏目面包屑导航dr_mobile_catpos函数 61. 新增手机分页函数mobilepages 62. 新增重新日志记录函数log_message 63. 新增目录扫描dr_dir_map函数 64. 新增文件扫描dr_file_map函数 65. 新增数据返回统一格式dr_return_data函数 66. 新增格式化输出文件大小format_file_size函数 67. 新增附件信息get_attachment函数 68. 新增统一返回json格式并退出程序dr_json函数 69. 新增将数组转换为字符串dr_array2string函数 70. 新增将字符串转换为数组dr_string2array函数 71. 新增根据文件扩展名获取文件预览信息dr_file_preview_html函数 72. 新增IP转为实际地址ip2address函数 73. 新增当前IP实际地址ip_address_info函数 74. 新增清除HTML标记clearhtml函数 75. 新增提取关键字dr_get_keywords函数 76. 新增提取描述信息dr_get_description函数 77. 新增获取内容中的缩略图get_content_img函数 78. 新增HTML实体字符转换code2html函数 79. 新增判断存在于数组中dr_in_array函数 80. 新增字符长度dr_strlen函数 81. 新增将路径进行安全转换变量模式dr_safe_replace_path函数 82. 新增站点手机配置 83. 新增是否需要检查外部访问 84. 新增关联字段 85. 新增信息表格字段 86. 新增单文件上传字段 87. 水印图片的透明度设置 88. 增加内容编辑时的更新时间字段

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值