我终于为一个我无法完成的小项目寻求帮助。
我在 Linux Ubuntu 16.04 和 Python 2.7.12 或 Python 3.5.2 上工作
这很简单:
我有一个包含数千个这种格式的比特币地址的 csv 文件:
12xApR3LKKobfMtPyorsyfpdQt51C1242P
1MqadAMYmwqvJPEYR5UhWHGhupuiXdQ5Pg
1P66WyUGcuPGTKH1ECwmrXoASPR1WP5dfa
1LWb1YtSoQ7m8RreJAEyasHK61jsQqMHGD
1BZnbtBXAKtjrA1suinXrf1s6pjhjPA7oG
166goQjUX3Lh3aN9SEXgcRwpPSBoJWtdDu
1C3pvanq8ZHDGrjfxQU7x8D13DS7d9XjLF
我想使用这个确实有效的函数将它们转换为 HASH160:
adr160 = base58.b58decode_check(adr58).encode('hex')[2:]
并将结果以相同的格式写入另一个文本或 csv 文件。
88374DB2A14DEA2925B19AF4D4AD84EB94FDE409
156732EBD650DF4AC212F5C8DE5DFBA4AE588B59
E4928C9EFDE55B17603D9539FB649D9457C293EB
...
我尝试了很多事情,但每次都有问题阻止我成功。
这是我最后的两次尝试:
import base58
import csv
adr58 =''
with open('sample.csv', 'rb') as csvfile:
adr58 = csv.reader(csvfile)
adr160 = base58.b58decode_check(adr58).encode('hex')[2:]
with open("Output.txt", "a+") as text_file:
text_file.write(adr160)
结果 :
" AttributeError: '_csv.reader' object has no attribute 'rstrip' "
第二次尝试是:
import base58
import pandas as pd
adr58 = pd.read_csv('sample.csv')
def convert(adr58):
print ("the address is: ")
adr160 = base58.b58decode_check(adr58).encode('hex')[2:]
f = open("hashed.txt", "w")
f.write(adr160)
f.close()
convert(adr58)
结果 :
" AttributeError: 'DataFrame' object has no attribute 'rstrip' "
我怎样才能以简单的方式做到这一点?我在这里完全不知所措。
提前感谢您的帮助。