file
आदेश एन्कोडिंग के बारे में "सर्वश्रेष्ठ अनुमान" बनाता है। एन्कोडिंग के बारे में जानकारी मुद्रित करने के -i
लिए बाध्य file
करने के लिए पैरामीटर का उपयोग करें ।
प्रदर्शन:
$ file -i *
umlaut-iso88591.txt: text/plain; charset=iso-8859-1
umlaut-utf16.txt: text/plain; charset=utf-16le
umlaut-utf8.txt: text/plain; charset=utf-8
यहाँ बताया गया है कि मैंने फाइलें कैसे बनाई:
$ echo ä > umlaut-utf8.txt
आजकल सब कुछ utf-8 है। लेकिन खुद को मनाओ:
$ hexdump -C umlaut-utf8.txt
00000000 c3 a4 0a |...|
00000003
Https://en.wikipedia.org/wiki/Com#Computer_encoding के साथ तुलना करें
अन्य एन्कोडिंग में परिवर्तित करें:
$ iconv -f utf8 -t iso88591 umlaut-utf8.txt > umlaut-iso88591.txt
$ iconv -f utf8 -t utf16 umlaut-utf8.txt > umlaut-utf16.txt
हेक्स डंप की जाँच करें:
$ hexdump -C umlaut-iso88591.txt
00000000 e4 0a |..|
00000002
$ hexdump -C umlaut-utf16.txt
00000000 ff fe e4 00 0a 00 |......|
00000006
तीनों को मिलाकर कुछ "अवैध" बनाएं:
$ cat umlaut-iso88591.txt umlaut-utf8.txt umlaut-utf16.txt > umlaut-mixed.txt
क्या file
कहता है:
$ file -i *
umlaut-iso88591.txt: text/plain; charset=iso-8859-1
umlaut-mixed.txt: application/octet-stream; charset=binary
umlaut-utf16.txt: text/plain; charset=utf-16le
umlaut-utf8.txt: text/plain; charset=utf-8
बिना -i
:
$ file *
umlaut-iso88591.txt: ISO-8859 text
umlaut-mixed.txt: data
umlaut-utf16.txt: Little-endian UTF-16 Unicode text, with no line terminators
umlaut-utf8.txt: UTF-8 Unicode text
file
आदेश "वैध" या "अवैध" का पता नहीं है। यह सिर्फ कुछ बाइट्स देखता है और अनुमान लगाने की कोशिश करता है कि एन्कोडिंग क्या हो सकता है। मनुष्य के रूप में हम यह पहचानने में सक्षम हो सकते हैं कि एक फ़ाइल "गलत" एन्कोडिंग में कुछ umlauts के साथ एक पाठ फ़ाइल है। लेकिन एक कंप्यूटर के रूप में इसे किसी प्रकार की कृत्रिम बुद्धि की आवश्यकता होगी।
हो सकता है कि कोई तर्क दे कि file
कृत्रिम बुद्धि कुछ प्रकार की है। फिर भी, भले ही यह बहुत सीमित है।
यहाँ file
कमांड के बारे में अधिक जानकारी है : http://www.linfo.org/file_command.html