politylink common
1.0.0
pip install politylink
如果您使用的是politylink.nlp.keyphrase ,请执行以下程序:
pip install git+https://github.com/boudinfl/pke.git
python -m nltk.downloader stopwords
提供GraphQlClient以访问PolityLink的GraphQl端点。
from politylink.graphql.client import GraphQLClient
client = GraphQLClient()
您可以使用exec方法执行任何GraphQl查询。
query = """
query {
Bill(filter: {submittedDate: {year: 2020, month: 1, day: 20}}) {
name
}
}
"""
client.exec(query)
应以JSON格式获得2020年1月20日提交的三项法案的姓名。
{'data': {'Bill': [{'name': '特定複合観光施設区域の整備の推進に関する法律及び特定複合観光施設区域整備法を廃止する法律案'},
{'name': '地方交付税法及び特別会計に関する法律の一部を改正する法律案'},
{'name': '平成三十年度歳入歳出の決算上の剰余金の処理の特例に関する法律案'}]}}
您还可以使用get_all_*方法将返回值作为Python类的实例而不是JSON检索。例如, get_all_bills允许您检索账单作为账单实例。
bills = client.get_all_bills(fields=['id', 'name'])
first_bill = bills[0]
print(f'{len(bills)}件の法律案を取得しました')
print(f'最初の法律案は「{first_bill.name}」({first_bill.id})です')
您应该获得所有账单的ID和名称。返回值是一个帐单实例,因此您可以使用点访问每个字段。
207件の法律案を取得しました
最初の法律案は「地方交付税法及び特別会計に関する法律の一部を改正する法律案」(Bill:s1QZfjoCPyfdXXbrplP3-A)です
您还可以通过将filter_作为参数来指定条件。有关更多详细信息,请参见高级版本。
GraphQlClclient是SGQLC的包装类,也可以在代码中组装查询。例如,如果您为第一个exec示例组装查询,则看起来像这样:
from politylink.graphql.schema import Query, _BillFilter, _Neo4jDateTimeInput
from sgqlc.operation import Operation
op = Operation(Query)
filter_ = _BillFilter(None)
filter_.submitted_date = _Neo4jDateTimeInput(year=2020, month=1, day=20)
bills = op.bill(filter=filter_)
bills.name()
client.exec(op)
组装的Operation会自动转换为字符串,因此可以将其直接传递给exec 。
您还可以将上面创建的过滤器_作为参数传递给get_all_*方法。
client.get_all_bills(fields=['name'], filter_=filter_)
前三个法案是作为法案实例获得的。
[Bill(name='地方交付税法及び特別会計に関する法律の一部を改正する法律案'),
Bill(name='平成三十年度歳入歳出の決算上の剰余金の処理の特例に関する法律案'),
Bill(name='特定複合観光施設区域の整備の推進に関する法律及び特定複合観光施設区域整備法を廃止する法律案')]