Wie kann ich mit Python SegWit-Adressen aus einer Mnemonik generieren?

Also habe ich ein Skript geschrieben, das BIP39-Mnemonics generiert. Ich möchte jetzt N native öffentliche SegWit-Schlüssel aus dieser Mnemonik generieren.

Ich habe dies gefunden , aber es generiert Legacy-Adressen. Es verwendet das Modul bip32utils.

def bip39(mnemonic_words):
    mobj = mnemonic.Mnemonic("english")
    seed = mobj.to_seed(mnemonic_words)

    bip32_root_key_obj = bip32utils.BIP32Key.fromEntropy(seed)
    bip32_child_key_obj = bip32_root_key_obj.ChildKey(
        44 + bip32utils.BIP32_HARDEN
    ).ChildKey(
        0 + bip32utils.BIP32_HARDEN
    ).ChildKey(
        0 + bip32utils.BIP32_HARDEN
    ).ChildKey(0).ChildKey(0)

    return {
        'mnemonic_words': mnemonic_words,
        'addr': bip32_child_key_obj.Address(),
        'publickey': binascii.hexlify(bip32_child_key_obj.PublicKey()).decode(),
        'privatekey': bip32_child_key_obj.WalletImportFormat(),
        'coin': 'BTC'
    }

if __name__ == '__main__':
    seed = 'input display smile visa surround learn solar hero vacuum parrot cigar devote'
    pprint.pprint(bip39(seed))

Ich nehme an, ich brauche bip44utils oder so, aber es existiert nicht. Ich habe versucht, mir bip-utils anzusehen, aber ich kann nicht herausfinden, wie ich meine Mnemonik in eine Adresse umwandeln kann.

Weiß jemand, wie ich eine Mnemonik in eine SegWit-Adresse umwandeln kann (so dass ich den Ableitungspfad ändern kann, um mehrere Adressen zu erhalten)?

BEARBEITEN (GELÖST):

Ich habe festgestellt, dass bitcoinlib dies tun kann.

from bitcoinlib.wallets import Wallet

passphrase = 'input display smile visa surround learn solar hero vacuum parrot cigar devote'

w = Wallet.create("Wallet1", witness_type='segwit', keys=passphrase, network='bitcoin')
WalletKeys = (w.get_keys(number_of_keys=10))

for k in WalletKeys:
    print(k.address)

Und jetzt funktioniert es so wie ich es wollte.

Antworten (1)

Wenn Sie nur eine Befehlszeile benötigen, können Sie es versuchen pip3 install btc-address-dump.

Hier ist ein Beispiel:

$ btc_address_dump "olympic wine chicken argue unaware bundle tunnel grid spider slot spell need"
mnemonic = olympic wine chicken argue unaware bundle tunnel grid spider slot spell need
private key (hex) = c7ac679b56f50bfd54dd924fe45a8dca7a1c2dced254b03dac22afc03adb9127
private key (WIF) = 5KLDyKtrScLYsKMJzVCt8Mf6Nn9DEV7V3fg8njfSZnqe7ZEMqzK
private key (WIF compressed) = L3urFcPsE2yHf5zeQjVSfUB8j8FEzX5cnmhjNsJfqjKgowPP4tmg
public key (uncompressed) = 044cd0aaeca3b636078583408e75edd77307b5190ca7a48bb9fbc1f2576c17dff1087190d91e26af594e3f8ecd3f4d3596c03c45d3b235da916903c930c6593cc4
public key (compressed) = 024cd0aaeca3b636078583408e75edd77307b5190ca7a48bb9fbc1f2576c17dff1
legacy address (p2pkh uncompressed) = 1Q5RqZctfcNkTPad2tuJSREByd2gB8xs63
legacy address (p2pkh compressed) = 12W36tm2jnreFiYdrzfE6cvRaKRbicEpnA
p2sh-segwit address (p2sh p2wpkh) = 3AzXxVUqdzvzEqVmdtmeVqRwc98uqwyh76
bech32 address (p2wpkh) = bc1qzp6lz6zy9p7k68r0a7lzfpkdxvj3yapynzuatt
Das sieht super aus danke. Ich habe jedoch Fehler bekommen, wenn ich laufe import btc_address_dump. Das sollte mit python3.8.5 funktionieren, oder? 🦄