Dalam Memaparkan Output Skrip Python pada Panel Conky, saya mencadangkan menjalankan skrip Python pada panel Conky untuk memaparkan kadar pertukaran Bitcoin dalam USD dan BRL. Walau bagaimanapun, disebabkan penggunaan memori yang lebih tinggi daripada jangkaan untuk tugas asas sedemikian, saya menulis semula skrip dalam Go. Kini, binari yang disusun mengendalikan tugas. Pendekatan ini sesuai untuk pemula Go, menawarkan peluang untuk mempelajari pengendalian API dan pemformatan teks untuk nilai kewangan. Berikut ialah pecahan:
Kod lengkap ada di penghujung artikel ini.
1 - Pakej dan Import
package main import ( "encoding/json" "fmt" "io" "net/http" "strconv" "github.com/dustin/go-humanize" )
- pakej utama: Tandai ini sebagai titik masuk program.
-
Perpustakaan Diimport:
- pengekodan/json: Untuk menghuraikan respons JSON daripada API.
- fmt: Untuk pemformatan dan pencetakan teks.
- io: Untuk membaca badan tindak balas.
- net/http: Untuk membuat permintaan HTTP.
- strconv: Untuk menukar rentetan kepada nombor.
- memanusiakan: Untuk menambah ribuan pemisah kepada nombor. Pasang melalui go get github.com/dustin/go-humanize.
2 - Pemalar Global
const ( apiURL = "https://economia.awesomeapi.com.br/json/last/BTC-USD,BTC-BRL" )
- apiURL: Titik akhir API untuk mengambil kadar pertukaran Bitcoin.
3 - Struktur untuk Penghuraian JSON
type CurrencyData struct { High string `json:"high"` Low string `json:"low"` } type APIResponse struct { BTCUSD CurrencyData `json:"BTCUSD"` BTCBRL CurrencyData `json:"BTCBRL"` }
- CurrencyData: Memegang nilai tinggi dan rendah untuk mata wang.
- APIResponse: Mewakili respons API penuh dengan kunci BTCUSD dan BTCBRL.
Teg JSON (json:"tinggi") memetakan medan struct kepada kekunci JSON.
4 - Berfungsi untuk Memformat Nilai Monetari
func formatCurrency(value string, prefix string) string { floatValue, err := strconv.ParseFloat(value, 64) if err != nil { return "N/A" } formattedValue := fmt.Sprintf("%s%s", prefix, humanize.FormatFloat("#,###.##", floatValue)) return formattedValue }
- Menukar nilai (rentetan) kepada apungan menggunakan strconv.ParseFloat.
- Memformatkan nombor dengan ribuan pemisah dan dua tempat perpuluhan, menambah awalan (mis., $ atau R$).
5 - Fungsi Utama
5.1 Permintaan API
resp, err := http.Get(apiURL) if err != nil { writeError(err) return } defer resp.Body.Close() body, err := io.ReadAll(resp.Body) if err != nil { writeError(err) return }
- http.Get(apiURL): Menghantar permintaan GET ke API.
- defer resp.Body.Close(): Memastikan badan tindak balas ditutup selepas diproses.
- io.ReadAll: Membaca badan tindak balas.
5.2 Penghuraian JSON
var data APIResponse if err := json.Unmarshal(body, &data); err != nil { writeError(err) return }
- json.Unmarshal: Menghuraikan respons JSON ke dalam struct APIResponse.
5.3 Pemformatan Data
usdAlta := formatCurrency(data.BTCUSD.High, "$$") usdBaixa := formatCurrency(data.BTCUSD.Low, "$$") brlAlta := formatCurrency(data.BTCBRL.High, "R$$") brlBaixa := formatCurrency(data.BTCBRL.Low, "R$$")
Memformatkan nilai yang disediakan API untuk paparan.
5.4 Pembinaan Hasil
formattedData := fmt.Sprintf( "\n\n${color white}BTC - USD\n${color}${color green} High: ${color}${color white}%s\n${color red} Low: ${color}${color white}%s\n\n"+ "${color white}BTC - BRL\n${color}${color green} High: ${color}${color white}%s\n${color red} Low: ${color}${color white}%s\n", usdAlta, usdBaixa, brlAlta, brlBaixa, ) fmt.Println(formattedData)
Mencipta rentetan output akhir dengan nilai yang diformatkan.
6 - Fungsi Pengelogan Ralat
func writeError(err error) { errMsg := fmt.Sprintf("Error: %v", err) fmt.Println(errMsg) }
Merakam ralat ke terminal.
? btc_data.go
Jalankan: pergi bina btc_data.go && ./btc_data.go
package main import ( "encoding/json" "fmt" "io" "net/http" "strconv" "github.com/dustin/go-humanize" )
Jika artikel ini membantu anda atau anda menikmatinya, pertimbangkan untuk menyumbang:
Atas ialah kandungan terperinci Skrip Kadar Bitcoin dalam Go. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Artikel ini menerangkan cara menggunakan alat PPROF untuk menganalisis prestasi GO, termasuk membolehkan profil, mengumpul data, dan mengenal pasti kesesakan biasa seperti CPU dan isu memori.

OpenSSL, sebagai perpustakaan sumber terbuka yang digunakan secara meluas dalam komunikasi yang selamat, menyediakan algoritma penyulitan, kunci dan fungsi pengurusan sijil. Walau bagaimanapun, terdapat beberapa kelemahan keselamatan yang diketahui dalam versi sejarahnya, yang sebahagiannya sangat berbahaya. Artikel ini akan memberi tumpuan kepada kelemahan umum dan langkah -langkah tindak balas untuk OpenSSL dalam sistem Debian. Debianopenssl yang dikenal pasti: OpenSSL telah mengalami beberapa kelemahan yang serius, seperti: Kerentanan Pendarahan Jantung (CVE-2014-0160): Kelemahan ini mempengaruhi OpenSSL 1.0.1 hingga 1.0.1f dan 1.0.2 hingga 1.0.2 versi beta. Penyerang boleh menggunakan kelemahan ini untuk maklumat sensitif baca yang tidak dibenarkan di pelayan, termasuk kunci penyulitan, dll.

Artikel ini membincangkan ujian unit menulis di GO, meliputi amalan terbaik, teknik mengejek, dan alat untuk pengurusan ujian yang cekap.

Artikel ini menunjukkan penciptaan dan stub di GO untuk ujian unit. Ia menekankan penggunaan antara muka, menyediakan contoh pelaksanaan mengejek, dan membincangkan amalan terbaik seperti menjaga mocks fokus dan menggunakan perpustakaan penegasan. Articl

Artikel ini meneroka kekangan jenis adat Go untuk generik. Ia memperincikan bagaimana antara muka menentukan keperluan jenis minimum untuk fungsi generik, meningkatkan keselamatan jenis dan kebolehgunaan semula kod. Artikel ini juga membincangkan batasan dan amalan terbaik

Artikel ini membincangkan pakej GO's Reflect, yang digunakan untuk manipulasi kod runtime, bermanfaat untuk siri, pengaturcaraan generik, dan banyak lagi. Ia memberi amaran tentang kos prestasi seperti pelaksanaan yang lebih perlahan dan penggunaan memori yang lebih tinggi, menasihati penggunaan yang bijak dan terbaik

Artikel ini meneroka menggunakan alat pengesanan untuk menganalisis aliran pelaksanaan aplikasi GO. Ia membincangkan teknik instrumentasi manual dan automatik, membandingkan alat seperti Jaeger, Zipkin, dan OpenTelemetry, dan menonjolkan visualisasi data yang berkesan

Artikel ini membincangkan menggunakan ujian yang didorong oleh jadual di GO, satu kaedah yang menggunakan jadual kes ujian untuk menguji fungsi dengan pelbagai input dan hasil. Ia menyoroti faedah seperti kebolehbacaan yang lebih baik, penurunan duplikasi, skalabiliti, konsistensi, dan a


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Penyesuai Pelayan SAP NetWeaver untuk Eclipse
Integrasikan Eclipse dengan pelayan aplikasi SAP NetWeaver.

MinGW - GNU Minimalis untuk Windows
Projek ini dalam proses untuk dipindahkan ke osdn.net/projects/mingw, anda boleh terus mengikuti kami di sana. MinGW: Port Windows asli bagi GNU Compiler Collection (GCC), perpustakaan import yang boleh diedarkan secara bebas dan fail pengepala untuk membina aplikasi Windows asli termasuk sambungan kepada masa jalan MSVC untuk menyokong fungsi C99. Semua perisian MinGW boleh dijalankan pada platform Windows 64-bit.

Dreamweaver CS6
Alat pembangunan web visual

Versi Mac WebStorm
Alat pembangunan JavaScript yang berguna