Format-Hex
Menampilkan file atau input lain sebagai heksadesimal.
Sintaks
Path (Default)
Format-Hex
[-Path] <string[]>
[<CommonParameters>]
LiteralPath
Format-Hex
-LiteralPath <string[]>
[<CommonParameters>]
ByInputObject
Format-Hex
-InputObject <Object>
[-Encoding <string>]
[-Raw]
[<CommonParameters>]
Deskripsi
Cmdlet Format-Hex menampilkan file atau input lain sebagai nilai heksadesimal. Untuk menentukan offset karakter dari output, tambahkan angka di paling kiri baris ke angka di bagian atas kolom untuk karakter tersebut.
Cmdlet Format-Hex dapat membantu Anda menentukan tipe file file yang rusak atau file yang mungkin tidak memiliki ekstensi nama file. Anda dapat menjalankan cmdlet ini, lalu membaca output heksadesimal untuk mendapatkan informasi file.
Saat menggunakan Format-Hex pada file, cmdlet mengabaikan karakter baris baru dan mengembalikan seluruh konten file dalam satu string dengan karakter baris baru yang dipertahankan.
Contoh
Contoh 1: Dapatkan representasi heksadesimal dari string
Perintah ini mengembalikan nilai heksadesimal dari string.
'Hello World' | Format-Hex
00 01 02 03 04 05 06 07 08 09 0A 0B 0C 0D 0E 0F
00000000 48 65 6C 6C 6F 20 57 6F 72 6C 64 Hello World
String Hello World dikirimkan alur ke cmdlet Format-Hex. Output heksadesimal dari Format-Hex menunjukkan nilai setiap karakter dalam string.
Contoh 2: Temukan jenis file dari output heksadesimal
Contoh ini menggunakan output heksadesimal untuk menentukan jenis file. Cmdlet menampilkan jalur lengkap file dan nilai heksadesimal.
Untuk menguji perintah berikut, buat salinan file PDF yang ada di komputer lokal Anda dan ganti nama file yang disalin menjadi File.t7f.
Format-Hex -Path .\File.t7f
Path: C:\Test\File.t7f
00 01 02 03 04 05 06 07 08 09 0A 0B 0C 0D 0E 0F
00000000 25 50 44 46 2D 31 2E 35 0D 0A 25 B5 B5 B5 B5 0D %PDF-1.5..%????.
00000010 0A 31 20 30 20 6F 62 6A 0D 0A 3C 3C 2F 54 79 70 .1 0 obj..<</Typ
00000020 65 2F 43 61 74 61 6C 6F 67 2F 50 61 67 65 73 20 e/Catalog/Pages
Cmdlet Format-Hex menggunakan parameter Jalur untuk menentukan nama file di direktori saat ini, File.t7f. Ekstensi file .t7f jarang terjadi, tetapi output heksadesimal %PDF menunjukkan bahwa itu adalah file PDF.
Contoh 3: Menampilkan output heksadesimal mentah
Secara default Format-Hex memilih output yang ringkas dari jenis data numerik: urutan byte tunggal atau byte ganda digunakan jika nilainya cukup kecil. Parameter Raw menonaktifkan perilaku ini.
PS> 1,2,3,1000 | Format-Hex
Path:
00 01 02 03 04 05 06 07 08 09 0A 0B 0C 0D 0E 0F
00000000 01 02 03 E8 03 ...è.
PS> 1,2,3,1000 | Format-Hex -Raw
Path:
00 01 02 03 04 05 06 07 08 09 0A 0B 0C 0D 0E 0F
00000000 01 00 00 00 02 00 00 00 03 00 00 00 E8 03 00 00 ............è...
Perhatikan perbedaan output. Parameter Raw menampilkan angka sebagai nilai 4 byte, benar untuk jenis Int32.
Parameter
-Encoding
Menentukan pengodean output. Ini hanya berlaku untuk input [string]. Parameter tidak berpengaruh pada jenis numerik. Nilai defaultnya adalah ASCII.
Nilai yang dapat diterima untuk parameter ini adalah sebagai berikut:
-
AsciiMenggunakan set karakter ASCII (7-bit). -
BigEndianUnicodeMenggunakan UTF-16 dengan urutan byte big-endian. -
UnicodeMenggunakan UTF-16 dengan urutan byte little-endian. -
UTF7Menggunakan UTF-7. -
UTF8Menggunakan UTF-8. -
UTF32Menggunakan UTF-32 dengan urutan byte little-endian.
Karakter non-ASCII dalam input adalah output sebagai karakter ? harfiah yang mengakibatkan hilangnya informasi.
Properti parameter
| Jenis: | String |
| Nilai default: | ASCII |
| Nilai yang diterima: | ASCII, BigEndianUnicode, Unicode, UTF7, UTF8, UTF32 |
| Mendukung wildcard: | False |
| DontShow: | False |
Kumpulan parameter
ByInputObject
| Position: | Named |
| Wajib: | False |
| Nilai dari alur: | False |
| Nilai dari alur berdasarkan nama properti: | False |
| Nilai dari argumen yang tersisa: | False |
-InputObject
Menentukan objek yang akan diformat. Masukkan variabel yang berisi objek atau ketik perintah atau ekspresi yang mendapatkan objek.
Hanya jenis skalar tertentu dan [System.IO.FileInfo] yang didukung.
Jenis skalar yang didukung adalah:
[string][byte]-
[int],[int32] -
[long],[int64]
Properti parameter
| Jenis: | Object |
| Nilai default: | None |
| Mendukung wildcard: | False |
| DontShow: | False |
Kumpulan parameter
ByInputObject
| Position: | Named |
| Wajib: | True |
| Nilai dari alur: | True |
| Nilai dari alur berdasarkan nama properti: | False |
| Nilai dari argumen yang tersisa: | False |
-LiteralPath
Menentukan jalur lengkap ke file. Nilai LiteralPath digunakan persis seperti yang diketikkan. Parameter ini tidak menerima karakter kartubebas. Untuk menentukan beberapa jalur ke file, pisahkan jalur dengan koma. Jika parameter LiteralPath menyertakan karakter escape, sertakan jalur dalam tanda kutip tunggal. PowerShell tidak menginterpretasikan karakter apa pun dalam satu string yang dikutip sebagai urutan escape. Untuk informasi lebih lanjut, lihat about_Quoting_Rules.
Properti parameter
| Jenis: | String[] |
| Nilai default: | None |
| Mendukung wildcard: | False |
| DontShow: | False |
| Alias: | PSPath |
Kumpulan parameter
LiteralPath
| Position: | Named |
| Wajib: | True |
| Nilai dari alur: | False |
| Nilai dari alur berdasarkan nama properti: | False |
| Nilai dari argumen yang tersisa: | False |
-Path
Menentukan jalur ke file. Gunakan titik (.) untuk menentukan lokasi saat ini. Karakter kartubebas (*) diterima dan dapat digunakan untuk menentukan semua item di lokasi. Jika parameter Jalur menyertakan karakter escape, sertakan jalur dalam tanda kutip tunggal. Untuk menentukan beberapa jalur ke file, pisahkan jalur dengan koma.
Properti parameter
| Jenis: | String[] |
| Nilai default: | None |
| Mendukung wildcard: | True |
| DontShow: | False |
Kumpulan parameter
Path
| Position: | 0 |
| Wajib: | True |
| Nilai dari alur: | False |
| Nilai dari alur berdasarkan nama properti: | False |
| Nilai dari argumen yang tersisa: | False |
-Raw
Secara default Format-Hex memilih output yang ringkas dari jenis data numerik: urutan byte tunggal atau byte ganda digunakan jika nilainya cukup kecil. Parameter Raw menonaktifkan perilaku ini.
Properti parameter
| Jenis: | SwitchParameter |
| Nilai default: | None |
| Mendukung wildcard: | False |
| DontShow: | False |
Kumpulan parameter
ByInputObject
| Position: | Named |
| Wajib: | False |
| Nilai dari alur: | False |
| Nilai dari alur berdasarkan nama properti: | False |
| Nilai dari argumen yang tersisa: | False |
CommonParameters
Cmdlet ini mendukung parameter umum: -Debug, -ErrorAction, -ErrorVariable, -InformationAction, -InformationVariable, -OutBuffer, -OutVariable, -PipelineVariable, -ProgressAction, -Verbose, -WarningAction, dan -WarningVariable. Untuk informasi selengkapnya, lihat about_CommonParameters.
Input
String
Anda dapat menyalurkan string ke cmdlet ini.
Output
ByteCollection
Cmdlet ini mengembalikan ByteCollection. Objek ini mewakili kumpulan byte. Ini termasuk metode yang mengonversi kumpulan byte menjadi string yang diformat seperti setiap baris output yang dikembalikan oleh Format-Hex. Jika Anda menentukan parameter Path atau LiteralPath, objek juga berisi jalur file yang berisi setiap byte.
Catatan
Windows PowerShell menyertakan alias berikut untuk Format-Hex:
fhx
Kolom output paling kanan mencoba merender byte sebagai karakter:
Umumnya, setiap byte ditafsirkan sebagai titik kode Unicode, yang berarti bahwa:
- Karakter ASCII yang dapat dicetak selalu dirender dengan benar
- Karakter UTF-8 multi-byte tidak pernah dirender dengan benar
- Karakter UTF-16 dirender dengan benar hanya jika byte urutan tingginya terjadi
NUL.