如何解决linux上有中文命名的文件名压缩后下载到windows上再解压出来都是乱码?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何解决linux上有中文命名的文件名压缩后下载到windows上再解压出来都是乱码?相关的知识,希望对你有一定的参考价值。
前提:由于文件过大必须通过压缩后再下载
尝试通过tar和rar都没有解决这个问题
解决办法, 一个是 用英文文件名。 另一个,把Linux系统的文件名转成GBK编码的。 不过这种转换有可能造成信息丢失。 因为 UTF8 不能 100% 转换成GBK。 但GBK可以完全转换成UTF8.
相关转换命令是 convmv 可能需要安装。
百度一下这个命令的用法。 转换完了再打包, 到Window下应该就正常了。
还是建议你最好用英文名。追问
现在的问题是服务器上已有上千的中文命名文件,所以英文命名什么的那是以后,现在需要解决的是当下问题,
你以上方法不可取,原因是:
在linux上把文件转换成GBK后linux上就是乱码了,虽然下载到windows上正常,但是这是把问题变得更严重,前提是linux上默认UTF8编码不可变。
两边都正常这是不现实的。 至少我没其他办法了。 Windows不支持UTF8这是硬伤。 你可以把Linux上的文件冗余一份。 就是说复制到别外的目录中一份转过编码后的, 专门用于打包供Windows下载。 哪怕只是打包时临时复制一份,转码打包后再删除也行。
convmv 命令支持批量操作的。 不要在NTFS和FAT文件系统中使用此命令,否则可能产生意外结果
这个不可取,我服务器上有上千个中文命名的文件名哪能一个个的修改
参考技术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上再解压出来都是乱码?的主要内容,如果未能解决你的问题,请参考以下文章