Linux:桌面系统中的文件后缀和类型-Linuxhttps://blog.csdn.net/weixin_45791458/category_12234591.html?spm=1001.2014.3001.

时间:2024-06-07 17:08:40

        Linux中的文件后缀与Windows系统有些不同,因为其似乎没有很重要,一个文件是否可执行对后缀没有要求。但是,后缀依然可以用于表示文件类型,也可以据此选择不同类型文件的默认打开方式。

        在Linux系统中,MIME(多用途互联网邮件扩展)文件类型机制是用来识别和处理不同类型文件的一种方式。MIME类型,也称为互联网媒体类型,最初是为了在电子邮件系统中识别不同格式的文件而设计的,但后来被广泛应用于HTTP传输中以及在操作系统如Linux中识别文件格式。

        MIME类型通常由两部分组成,类型(type)和子类型(subtype),用斜线分隔。例如,test/html表示HTML文档,image/jpeg表示JPEG图像文件。

        /usr/share/mime目录中有一些XML文件,它们是自动生成的,在安装或更新shared-mime-info包时由update-mime-database命令更新,它们规定了MIME类型、以及文件后缀和文件类型的映射关系。

        /usr/share/mime目录下的types文件中包括了目前的所有MIME类型,如下所示。

***********************
text/xmcd
video/3gpp
video/3gpp2
video/annodex
video/dv
video/isivideo
video/mp2t
video/mp4
video/mpeg
video/ogg
video/quicktime
video/vnd.mpegurl
video/vnd.rn-realvideo
video/vnd.vivo
video/wavelet
video/webm
video/x-anim
video/x-flic
***********************

        下面用/usr/share/mime/text目录下x-python.xml文件进行举例说明。

<?xml version="1.0" encoding="utf-8"?>
<mime-type xmlns="http://www.freedesktop.org/standards/shared-mime-info" type="text/x-python">
  <!--Created automatically by update-mime-database. DO NOT EDIT!-->
  <comment>Python script</comment>
  <comment xml:lang="ar">سكربت بايثون</comment>
  <comment xml:lang="be@latin">Skrypt Python</comment>
  <comment xml:lang="bg">Скрипт — Python</comment>
  <comment xml:lang="ca">script Python</comment>
  <comment xml:lang="cs">skript Python</comment>
  <comment xml:lang="da">Pythonprogram</comment>
  <comment xml:lang="de">Python-Skript</comment>
  <comment xml:lang="el">Δέσμη ενεργειών Python</comment>
  <comment xml:lang="en_GB">Python script</comment>
  <comment xml:lang="eo">Python-skripto</comment>
  <comment xml:lang="es">secuencia de órdenes en Python</comment>
  <comment xml:lang="eu">Python script-a</comment>
  <comment xml:lang="fi">Python-komentotiedosto</comment>
  <comment xml:lang="fo">Python boðrøð</comment>
  <comment xml:lang="fr">script Python</comment>
  <comment xml:lang="ga">script Python</comment>
  <comment xml:lang="gl">Script en Python</comment>
  <comment xml:lang="he">תסריט Python</comment>
  <comment xml:lang="hr">Python skripta</comment>
  <comment xml:lang="hu">Python-parancsfájl</comment>
  <comment xml:lang="ia">Script Python</comment>
  <comment xml:lang="id">Skrip Python</comment>
  <comment xml:lang="it">Script Python</comment>
  <comment xml:lang="ja">Python スクリプト</comment>
  <comment xml:lang="kk">Python сценарийі</comment>
  <comment xml:lang="ko">파이썬 스크립트</comment>
  <comment xml:lang="lt">Python scenarijus</comment>
  <comment xml:lang="lv">Python skripts</comment>
  <comment xml:lang="ms">Skrip Python</comment>
  <comment xml:lang="nb">Python-skript</comment>
  <comment xml:lang="nl">Python-script</comment>
  <comment xml:lang="nn">Python-skript</comment>
  <comment xml:lang="oc">escript Python</comment>
  <comment xml:lang="pl">Skrypt Python</comment>
  <comment xml:lang="pt">script Python</comment>
  <comment xml:lang="pt_BR">Script Python</comment>
  <comment xml:lang="ro">Script Python</comment>
  <comment xml:lang="ru">сценарий Python</comment>
  <comment xml:lang="sk">Skript Python</comment>
  <comment xml:lang="sl">Skriptna datoteka Python</comment>
  <comment xml:lang="sq">Script Python</comment>
  <comment xml:lang="sr">Питонова скрипта</comment>
  <comment xml:lang="sv">Pythonskript</comment>
  <comment xml:lang="tr">Python betiği</comment>
  <comment xml:lang="uk">скрипт мовою Python</comment>
  <comment xml:lang="vi">Văn lệnh Python</comment>
  <comment xml:lang="zh_CN">Python 脚本</comment>
  <comment xml:lang="zh_TW">Python 指令稿</comment>
  <sub-class-of type="application/x-executable"/>
  <sub-class-of type="text/plain"/>
  <glob pattern="*.py"/>
  <glob pattern="*.pyx"/>
  <glob pattern="*.wsgi"/>
</mime-type>

        XML文件中类似<comment>Python script</comment>的字段,规定了在桌面系统下,text/x-python类型文件在进行查询时显示的类型。最后的<glob pattern="*.py"/>字段,规定了哪些后缀的文件会被识别为text/x-python类型,不加说明后缀是大小写不敏感的,即.py、.PY、.pY和.Py都会被识别为text/x-python类型。

        下面给出了一个大小写敏感的例子,出现在x-c++src.xml中,其中的<glob pattern="*.C" case-sensitive="true"/>字段说明了只有大写C后缀的文件才会被识别为text/x-c++src类型。

<?xml version="1.0" encoding="utf-8"?>
<mime-type xmlns="http://www.freedesktop.org/standards/shared-mime-info" type="text/x-c++src">
  <!--Created automatically by update-mime-database. DO NOT EDIT!-->
  <comment>C++ source code</comment>
  <comment xml:lang="ar">شفرة مصدر سي++</comment>
  <comment xml:lang="be@latin">Kryničny kod C++</comment>
  <comment xml:lang="bg">Изходен код — C++</comment>
  <comment xml:lang="ca">codi font en C++</comment>
  <comment xml:lang="cs">zdrojový kód C++</comment>
  <comment xml:lang="da">C++-kildekode</comment>
  <comment xml:lang="de">C++-Quelltext</comment>
  <comment xml:lang="el">Πηγαίος κώδικας C++</comment>
  <comment xml:lang="en_GB">C++ source code</comment>
  <comment xml:lang="eo">C++-fontkodo</comment>
  <comment xml:lang="es">código fuente en C++</comment>
  <comment xml:lang="eu">C++ iturburu-kodea</comment>
  <comment xml:lang="fi">C++-lähdekoodi</comment>
  <comment xml:lang="fo">C++ keldukota</comment>
  <comment xml:lang="fr">code source C++</comment>
  <comment xml:lang="ga">cód foinseach C++</comment>
  <comment xml:lang="gl">código fonte de C++</comment>
  <comment xml:lang="he">קוד מקור של C++‎</comment>
  <comment xml:lang="hr">C++ izvorni kod</comment>
  <comment xml:lang="hu">C++-forráskód</comment>
  <comment xml:lang="ia">Codice-fonte C++</comment>
  <comment xml:lang="id">Kode program C++</comment>
  <comment xml:lang="it">Codice sorgente C++</comment>
  <comment xml:lang="ja">C++ ソースコード</comment>
  <comment xml:lang="ka">C++-ის საწყისი კოდი</comment>
  <comment xml:lang="kk">C++ бастапқы коды</comment>
  <comment xml:lang="ko">C++ 소스 코드</comment>
  <comment xml:lang="lt">C++ pradinis kodas</comment>
  <comment xml:lang="lv">C++ pirmkods</comment>
  <comment xml:lang="ms">Kod sumber C++</comment>
  <comment xml:lang="nb">C++-kildekode</comment>
  <comment xml:lang="nl">C++-broncode</comment>
  <comment xml:lang="nn">C++-kjeldekode</comment>
  <comment xml:lang="oc">còde font C++</comment>
  <comment xml:lang="pl">Kod źródłowy C++</comment>
  <comment xml:lang="pt">código origem C++</comment>
  <comment xml:lang="pt_BR">Código-fonte C++</comment>
  <comment xml:lang="ro">Cod sursă C++</comment>
  <comment xml:lang="ru">исходный код C++</comment>
  <comment xml:lang="sk">Zdrojový kód jazyka C++</comment>
  <comment xml:lang="sl">Datoteka izvorne kode C++</comment>
  <comment xml:lang="sq">Kod burues C++</comment>
  <comment xml:lang="sr">Ц++ изворни ко̂д</comment>
  <comment xml:lang="sv">C++-källkod</comment>
  <comment xml:lang="tr">C++ kaynak kodu</comment>
  <comment xml:lang="uk">вихідний код мовою C++</comment>
  <comment xml:lang="vi">Mã nguồn C++</comment>
  <comment xml:lang="zh_CN">C++ 源代码</comment>
  <comment xml:lang="zh_TW">C++ 源碼</comment>
  <sub-class-of type="text/x-csrc"/>
  <glob pattern="*.cpp"/>
  <glob pattern="*.cxx"/>
  <glob pattern="*.cc"/>
  <glob pattern="*.C" case-sensitive="true"/>
  <glob pattern="*.c++"/>
</mime-type>

        下图展示了在桌面系统GNOME中,一个.py后缀文件的类型查询结果。 

        可以看出首先根据系统语言(这里是默认),显示了<comment>字段规定的类型名,并且在小括号中显示了MIME类型。

        不同的桌面系统的显示结果可能有差异,下面是桌面系统XFCE中,一个.py后缀文件的类型查询结果。

        其中根据系统语言(这里是zh_CN),显示了<comment>字段规定的类型名,即Python 脚本。

        需要注意的是,一个有后缀的文件,显示出来的类型是由后缀决定的,这可能与文件真实类型不符合。如一个可执行二进制文件,如果重命名以.py为后缀,则其显示出来的类型会是错误的Python 脚本。所以一个文件的后缀只是对其类型的一个暗示,但并不确保其准确性。如果要准确识别一个文件的类型,可以使用file命令,它是通过文件的魔术头识别文件类型的,因此更为准确,如下所示。

$ file test.py
test.py: ELF 64-bit LSB executable, x86-64, version 1 (SYSV), dynamically linked (uses shared libs), for GNU/Linux 2.6.32, BuildID[sha1]=8c8cfe14852611f912f695c4ff7fae0b6607382d, not stripped

        对于没有后缀的文件,桌面系统会根据文件内容尝试推断其类型,即如果他是一个二进制文件,则可能推断为executable (application/x-executable)类型。下面是一个例子展示了一个没有后缀的jupyter+json格式的文件被正确识别为了Jupyter Notebook (application/x-ipynb+json)类型。

{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# 简单的Jupyter Notebook"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "print('Hello, world!')"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "name": "python3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}