python - 在Python中逐行将json-ish列表写入csv以获取比特币地址

标签 python json csv bitcoin

我正在查询onename api努力获取所有用户的比特币地址。

目前,我正在以 json 式列表的形式获取所有用户信息,然后将输出通过管道传输到文件,如下所示:

[{'0': {'owner_address': '1Q2Tv6f9vXbdoxRmGwNrHbjrrK4Hv6jCsz', 'zone_file': '{"avatar": {"url": "https://s3.amazonaws.com/kd4/111"}, "bitcoin": {"address": "1NmLvYVEZqPGeQNcgFS3DdghpoqaH4r5Xh"}, "cover": {"url": "https://s3.amazonaws.com/dx3/111"}, "facebook": {"proof": {"url": "https://facebook.com/jasondrake1978/posts/10152769170542776"}, "username": "jasondrake1978"}, "graph": {"url": "https://s3.amazonaws.com/grph/111"}, "location": {"formatted": "Mechanicsville, Va"}, "name": {"formatted": "Jason Drake"}, "twitter": {"username": "000001"}, "v": "0.2", "website": "http://1642.com"}', 'verifications': [{'proof_url': 'https://facebook.com/jasondrake1978/posts/10152769170542776', 'service': 'facebook', 'valid': False, 'identifier': 'jasondrake1978'}], 'profile': {'website': 'http://1642.com', 'cover': {'url': 'https://s3.amazonaws.com/dx3/111'}, 'facebook': {'proof': {'url': 'https://facebook.com/jasondrake1978/posts/10152769170542776'}, 'username': 'jasondrake1978'}, 'twitter': {'username': '000001'}, 'bitcoin': {'address': '1NmLvYVEZqPGeQNcgFS3DdghpoqaH4r5Xh'}, 'name': {'formatted': 'Jason Drake'}, 'graph': {'url': 'https://s3.amazonaws.com/grph/111'}, 'location': {'formatted': 'Mechanicsville, Va'}, 'avatar': {'url': 'https://s3.amazonaws.com/kd4/111'}, 'v': '0.2'}}}]

我真正感兴趣的是字段{"address": "1NmLvYVEZqPGeQNcgFS3DdghpoqaH4r5Xh"},其余的东西我不需要,我只想要每个用户的地址。

有没有一种方法可以让我使用 python 仅将地址写入文件?

我想把它写成这样:

1NmLvYVEZqPGeQNcgFS3DdghpoqaH4r5Xh,
1GA9RVZHuEE8zm4ooMTiqLicfnvymhzRVm,
1BJdMS9E5TUXxJcAvBriwvDoXmVeJfKiFV,
1NmLvYVEZqPGeQNcgFS3DdghpoqaH4r5Xh,
...

等等。

我已经使用dumpdumps等尝试了多种不同的方法,但我还无法确定它。

我的代码如下所示:

import os
import json
import requests
#import py2neo
import csv


# set up authentication parameters
#py2neo.authenticate("46.101.180.63:7474", "neo4j", "uni-bonn")

# Connect to graph and add constraints.
neo4jUrl = os.environ.get('NEO4J_URL',"http://46.101.180.63:7474/db/data/")
#graph = py2neo.Graph(neo4jUrl)

# Add uniqueness constraints.
#graph.run("CREATE CONSTRAINT ON (q:Person) ASSERT q.id IS UNIQUE;")

# Build URL.
apiUrl = "https://api.onename.com/v1/users"
# apiUrl = "https://raw.githubusercontent.com/s-matthew-english/26.04/master/test.json"

# Send GET request.
Allusersjson = requests.get(apiUrl, headers = {"accept":"application/json"}).json()

#print(json)])
UsersDetails=[]
for username in Allusersjson['usernames']:
    usernamex= username[:-3]
    apiUrl2="https://api.onename.com/v1/users/"+usernamex+"?app-id=demo-app-id&app-secret=demo-app-secret"
    userinfo=requests.get(apiUrl2, headers = {"accept":"application/json"}).json()
    # try:
    #     if('bitcoin' not in userinfo[usernamex]['profile']):
    #         continue
    #     else:
    #         UsersDetails.append(userinfo)
    # except:
    #     continue
    try:
        address = userinfo[usernamex]["profile"]["bitcoin"]["address"]
        UsersDetails.append(address)
    except KeyError:
        pass  # no address

out = "\n".join(UsersDetails)
print(out)
open("out.csv", "w").write(out)

# f = csv.writer(open("test.csv", "wb+"))


# Build query.
query = """
RETURN {json}
"""

# Send Cypher query.
# py2neo.CypherQuery(graph, query).run(json=json)
# graph.run(query).run(json=json)

#graph.run(query,json=json)

无论如何,在这种情况下,将这些地址写成 csv 的最佳方法是什么:/


更新

我运行了它,一开始它有效,但后来出现以下错误: enter image description here

最佳答案

而不是将所有信息添加到 UsersDetails 列表中

UsersDetails.append(userinfo)

您可以仅添加相关部分(地址)

try:
    address = userinfo[usernamex]["profile"]["bitcoin"]["address"]
    UsersDetails.append(address)
except KeyError:
    pass  # no address
except TypeError:
    pass  # illformed data

要将值打印到屏幕上:

out = "\n".join(UsersDetails)  
print(out)

(将“\n”替换为“,”以获取逗号分隔的输出,而不是每行一个)

保存到文件:

open("out.csv", "w").write(out)

关于python - 在Python中逐行将json-ish列表写入csv以获取比特币地址,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39308153/

相关文章:

python - 如何获取div之外的文本?

Python:元素未附加到页面文档

javascript - 通过添加key修改Json结果

python - 合并两个 numpy 掩码数组的有效方法

json - 为什么在转换 JSON 时,powershell 在单行和两行中给出不同的结果?

javascript - 从已运行的进程中打开 chrome 扩展程序的后台页面

Python Pandas read_csv 跳过前 x 行和后 y 行

python - 将网页中的表格数据写入 csv 文件

objective-c - 如何在 iPhone 上将 NSMutableArray 转换为 CSV 文件?

python - scrapy - 在 http 代码上调用 process_exception