如何解决linux上有中文命名的文件名压缩后下载到windows上再解压出来都是乱码?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何解决linux上有中文命名的文件名压缩后下载到windows上再解压出来都是乱码?相关的知识,希望对你有一定的参考价值。

前提:由于文件过大必须通过压缩后再下载

尝试通过tar和rar都没有解决这个问题

Linux系统默认的字符编码是 UTF-8 Windows 是 GBK 编码,不支持UTF8. 所以 Linux下 的中文文件名到 Windwos下就成了乱码。

解决办法, 一个是 用英文文件名。 另一个,把Linux系统的文件名转成GBK编码的。 不过这种转换有可能造成信息丢失。 因为 UTF8 不能 100% 转换成GBK。 但GBK可以完全转换成UTF8.

相关转换命令是 convmv 可能需要安装。
百度一下这个命令的用法。 转换完了再打包, 到Window下应该就正常了。
还是建议你最好用英文名。追问

现在的问题是服务器上已有上千的中文命名文件,所以英文命名什么的那是以后,现在需要解决的是当下问题,
你以上方法不可取,原因是:
在linux上把文件转换成GBK后linux上就是乱码了,虽然下载到windows上正常,但是这是把问题变得更严重,前提是linux上默认UTF8编码不可变。

追答

两边都正常这是不现实的。 至少我没其他办法了。 Windows不支持UTF8这是硬伤。 你可以把Linux上的文件冗余一份。 就是说复制到别外的目录中一份转过编码后的, 专门用于打包供Windows下载。 哪怕只是打包时临时复制一份,转码打包后再删除也行。

convmv 命令支持批量操作的。 不要在NTFS和FAT文件系统中使用此命令,否则可能产生意外结果

参考技术A linux和windows字符集不一样造成的,更改成一样的就行了,可以把压缩包的名字命名成应为的再下载追问

这个不可取,我服务器上有上千个中文命名的文件名哪能一个个的修改

参考技术B 这个是 xbox360版本的生化6 而且只是生化6的demo 即 试玩版而已你有 360这个游戏机么 没有就别想了 PC版还没发售呢

Linux文件压缩和打包(上)

6.1压缩打包介绍

6.2gzip压缩工具

6.3bzip2压缩工具

6.4xz压缩工具

文件压缩后的大小不能更具压缩工具来定论,他的大小是根据文件的内容和压缩工具一起定论的。

6.1压缩打包介绍

技术分享图片

      我们平时在网上下载文件一般都是压缩的,压缩会使我们的文件空间缩小。压缩文件我们在网上传输的时间也会有所减少,带宽资源也会减少。说到带宽其实我们家庭使用的带宽和公司使用的不是一样的,家庭使用的下载速度和上传速度不对等,而公司的是对等的。所以公司的宽带比较贵。如果我们服务器上的文件经常被下载我们就要对文件进行压缩了(这样我们可以节约很多带宽资源)。

      之前我们说过windows系统的文件后缀名可以分类,但是在我们linux系统里面文件的后缀名没有这么重要,但是我们为了好区分我们把linux系统里面相同的文件,使用一样后缀名。

6.2gzip压缩工具

技术分享图片

[[email protected] ~]# cd /tmp/
[[email protected] tmp]# ls
1.1.txt
1.2.txt
1.txt
fstab
newdisk
passwd.sh
systemd-private-4a8637beb8de42fb8464053cf2d212d8-chronyd.service-qRi1F0
systemd-private-4a8637beb8de42fb8464053cf2d212d8-vgauthd.service-KXhyWb
systemd-private-4a8637beb8de42fb8464053cf2d212d8-vmtoolsd.service-xaK1rP
systemd-private-9efcc82ee01b48909302a65e60af7a1d-chronyd.service-1IixSo
systemd-private-9efcc82ee01b48909302a65e60af7a1d-vgauthd.service-7iWWfH
systemd-private-9efcc82ee01b48909302a65e60af7a1d-vmtoolsd.service-JqnO61
systemd-private-a655ede1d77c4fa6ae782f90c506592b-chronyd.service-dQVYew
systemd-private-a655ede1d77c4fa6ae782f90c506592b-vgauthd.service-E2oycH
systemd-private-a655ede1d77c4fa6ae782f90c506592b-vmtoolsd.service-YXlLvS
txt
xxx.conf
[[email protected] tmp]# mkdir d6z
[[email protected] tmp]# cd !$
cd d6z
[[email protected] d6z]# find /etc/ -type f -name "*conf" -exec cat {} >> 1.txt \;【多看看这张find的使用方法】
[[email protected] d6z]# du -sh 1.txt 【查看文件或者目录的大小】
240K    1.txt
[[email protected] d6z]# find /etc/ -type f -name "*conf" -exec cat {} >> 1.txt \;
[[email protected] d6z]# du -sh 1.txt 
704K    1.txt
[[email protected] d6z]# cp 1.txt 2.txt
[[email protected] d6z]# cat 2.txt >> 1.txt 
[[email protected] d6z]# du -sh 1.txt 
1.2M    1.txt
[[email protected] d6z]# cat 2.txt >> 1.txt 
[[email protected] d6z]# du -sh 1.txt 
2.2M    1.txt
[[email protected] d6z]# cat 2.txt >> 1.txt 
[[email protected] d6z]# du -sh 1.txt 
2.2M    1.txt
[[email protected] d6z]# cat 2.txt >> 1.txt 
[[email protected] d6z]# du -sh 1.txt 
4.2M    1.txt

[[email protected] d6z]# wc -l 1.txt 【查看一个文件有多少行】
60770 1.txt
[[email protected] d6z]# gzip 1.txt 【压缩1.txt文件】
[[email protected] d6z]# du -sh 1.txt 【我们在查看文件的大小的时候显示没有这个文件了】
du: 无法访问"1.txt": 没有那个文件或目录
[[email protected] d6z]# ls 【可以看到我们的1.txt文件没有了多出来的是1.txt.gz】
1.txt.gz  2.txt
[[email protected] d6z]# gzip -d 1.txt.gz 【-d选项会解压缩我们的文件】
[[email protected] d6z]# ls
1.txt  2.txt
[[email protected] d6z]# du -sh 1.txt 【压缩之前这个文件大小是4.2M,压缩之后我们再解压发现我们文件大小变成了2.4M,这是因为我们之前的文件他就像海绵一样内存是有空隙的,而我们压缩之后再解压就会导致我们文件大小发生变化。】
2.4M    1.txt

[[email protected] d6z]# wc -l 1.txt 【我们再次查看文件的行数是没有发生变化的】
60770 1.txt
gzip压缩级别

gzip压缩是有级别的,分别从1到9个级别。压缩级别越高cup耗费的资源越多。

1级别是最不严谨的(就是压缩的文件没有9级别的小)

9级别是最严谨的(就是压缩的文件比1级别小的多)

[[email protected] d6z]# ls
1.txt  2.txt
[[email protected] d6z]# gzip -1 1.txt 【指定压缩1级别】
[[email protected] d6z]# du -sh 1.txt.gz 【压缩文件1.txt.gz大小732k】
732K    1.txt.gz
[[email protected] d6z]# gunzip 1.txt.gz 【这也是一个解压缩的命令和-d选项作用一样的】
[[email protected] d6z]# gzip -9 1.txt 【指定压缩9级别】
[[email protected] d6z]# du -sh 1.txt.gz 【压缩文件1.txt.gz大小616k】
616K    1.txt.gz
[[email protected] d6z]# gzip -d 1.txt.gz 
[[email protected] d6z]# gzip 1.txt 【如果我们不指定级别默认是6级别】
[[email protected] d6z]# du -sh 1.txt.gz 【默认压缩文件1.txt.gz大小620k】
620K    1.txt.gz
[[email protected] d6z]# file 1.txt.gz 【查看我们压缩文件的详细信息】
1.txt.gz: gzip compressed data, was "1.txt", from Unix, last modified: Fri Jan  5 06:59:22 2018
[[email protected] d6z]# zcat 1.txt.gz 【这个命令可以查看我们压缩文件的内容】
[[email protected] d6z]# ls
1.txt.gz  2.txt
[[email protected] d6z]# gunzip 1.txt.gz 
[[email protected] d6z]# gzip -c 1.txt > /tmp/1.txt.gz【这种方法压缩文件,可以指定定我们压缩后的文件放到哪里,而且我们的源文件不会消失。上面的实验压缩我们源文件消失只有压缩文件。】
[[email protected] d6z]# ls
1.txt  2.txt
[[email protected] d6z]# ls /tmp/1.txt.gz
/tmp/1.txt.gz

[[email protected] d6z]# file !$【file我们看一下】
file /tmp/1.txt.gz
/tmp/1.txt.gz: gzip compressed data, was "1.txt", from Unix, last modified: Fri Jan  5 06:59:22 2018

[[email protected] d6z]# gzip -d -c /tmp/1.txt.gz > /tmp/d6z/jieya1.txt.gz【我么也可以指定解压出来的文件放到哪里,而且原来的压缩文件不会消失。上面的实验我们压缩文件解压后会消失。】
[[email protected] d6z]# du -sh 1.txt jieya1.txt.gz 
2.4M    1.txt
2.4M    jieya1.txt.gz
[[email protected] d6z]# wc -l 1.txt jieya1.txt.gz 
  60770 1.txt
  60770 jieya1.txt.gz
 121540 总用量

6.3bzip2压缩工具

技术分享图片

bzip2工具压缩的文件比gzip工具压缩的文件要狠,文件压缩越狠cpu耗费的资源越多。默认级别9

[[email protected] d6z]# bzip2 1.txt 【压缩命令,提示我们没有安装bzip2工具】
-bash: bzip2: 未找到命令
[[email protected] d6z]# yum install -y bzip2
[[email protected] d6z]# bzip2 1.txt 【压缩命令】
[[email protected] d6z]# ls
1.txt.bz2  2.txt  jieya1.txt.gz
[[email protected] d6z]# du -sh 1.txt.bz2 【查看我们的使用bzip2压缩后的文件大小】
244K    1.txt.bz2【我们可以看到他的压缩很小,我们之前使用gzip压缩的时候的大小是620k
[[email protected] d6z]# bzip2 -d 1.txt.bz2 【-d选项是解压缩的意思】
[[email protected] d6z]# ls
1.txt  2.txt  jieya1.txt.gz
[[email protected] d6z]# du -sh 1.txt 【没有压缩的文件大小】
2.4M    1.txt
[[email protected] d6z]# bzip2 1.txt 
[[email protected] d6z]# bunzip2 1.txt.bz2 【解压缩文件命令,和-d选项一样】
[[email protected] d6z]# ls
1.txt  2.txt  jieya1.txt.gz
[[email protected] d6z]# bzip2 -c 1.txt > 3.txt.bz2【保留源文件压缩,并且指定压缩文件的路径】
[[email protected] d6z]# ls
1.txt  2.txt  3.txt.bz2  jieya1.txt.gz

[[email protected] d6z]# file 1.txt.bz2 【使用这个命令可以查看我们压缩文件的详细信息】
1.txt.bz2: bzip2 compressed data, block size = 900k

有的时候有的人就是把压缩的文件后缀名给你改了这个时候你cat查看是没有用的里面都是二进制文件。这个时候我们就想到用file命令查看这个文件看看他是什么文件

[[email protected] d6z]# ls
1.txt.bz2  2.txt  3.txt.bz2  jieya1.txt.gz
[[email protected] d6z]# mv 3.txt.bz2 3.txt
[[email protected] d6z]# ls
1.txt.bz2  2.txt  3.txt  jieya1.txt.gz
[[email protected] d6z]# less 3.txt 
"3.txt" may be a binary file.  See it anyway? 
[[email protected] d6z]# file 3.txt 
3.txt: bzip2 compressed data, block size = 900k
[[email protected] d6z]# file 2.txt 
2.txt: UTF-8 Unicode text

[[email protected] d6z]# bzcat 3.txt.bz2 【我们可以使用这个命令查看一个压缩文件】

6.4xz压缩工具

技术分享图片

xz工具压缩的文件比bzip2工具压缩的文件还要狠,当然文件压缩越狠cpu耗费的资源越多。默认级别9

下面的命令就不做详细介绍你可以参照上面的两个压缩工具来理解。

[[email protected] d6z]# ls
1.txt  2.txt  3.txt.bz2  jieya1.txt.gz
[[email protected] d6z]# xz 1.txt 
[[email protected] d6z]# ls
1.txt.xz  2.txt  3.txt.bz2  jieya1.txt.gz
[[email protected] d6z]# du -sh 1.txt.xz 
56K    1.txt.xz
[[email protected] d6z]# unxz 1.txt.xz 
[[email protected] d6z]# ls
1.txt  2.txt  3.txt.bz2  jieya1.txt.gz
[[email protected] d6z]# du -sh 1.txt 
2.4M    1.txt
[[email protected] d6z]# xz -z 1.txt 
[[email protected] d6z]# ls
1.txt.xz  2.txt  3.txt.bz2  jieya1.txt.gz
[[email protected] d6z]# xz -d -c 1.txt.xz > /tmp/1.txt.xz
[[email protected] d6z]# xz -c /tmp/1.txt > /tmp/d6z/5.txt.xz

[[email protected] d6z]# ls
1.txt.xz  2.txt  3.txt.bz2  5.txt.xz  jieya1.txt.gz

[[email protected] d6z]# xzcat 5.txt.xz 

技术分享图片

技术分享图片

技术分享图片

技术分享图片

阿铭linux:http://v.apelearn.com

MOMCO-51CTO博客:http://blog.51cto.com/13518197


以上是关于如何解决linux上有中文命名的文件名压缩后下载到windows上再解压出来都是乱码?的主要内容,如果未能解决你的问题,请参考以下文章

linux 压缩 上传到ftp后下载回来文件损坏

ZIP格式的文件怎么解压?

linux文件经 windows系统 之后出现 权限缺失 的解决方法

压缩文件zip怎么解压

linux的分卷打包文件下载到我的电脑后怎么解压缩?

请问:linux rename命令如何在文件名前面加连续数字序列号?