Rumah >pembangunan bahagian belakang >Golang >Skrip Kadar Bitcoin dalam Go

Skrip Kadar Bitcoin dalam Go

Barbara Streisand
Barbara Streisandasal
2025-01-18 14:03:09672semak imbas

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: Skrip Kadar Bitcoin dalam Go

Atas ialah kandungan terperinci Skrip Kadar Bitcoin dalam Go. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn