-
Notifications
You must be signed in to change notification settings - Fork 203
Amendments
Amendments are scraped as a part of the bill scraper. The bill scraper outputs amendment files for any bill it processes.
Every amendment has a JSON file, data.json, with fields related to a amendments's ID, status, and history.
The output files are in the following location:
congress/[congress]/amendments/[amendment_type]/[amendment_type][number]/data.{json.xml}
The data examples below use excerpts from H.Amdt. 183 in the 113th Congress where possible.
{
"amendment_id": "hamdt183-113",
"amendment_type": "hamdt",
"chamber": "h",
"congress": "113",
"number": 183,
"updated_at": "2013-11-02T07:31:09-04:00"
}
Bills are uniquely identified by a Congress, amendment type, and number, much like bills. Amendments die at the end of a Congress and numbering resets with each Congress. (See bills.)
amendment_type
and chamber
indicate the type of the amendment. In almost all cases amendment_type
is either hamdt
for House amendments or samdt
for Senate amendments. In the 97th and 98th Congresses, there appear some "Senate Unprinted Amendments". For these amendments, the amendment_type is supamdt
. The chamber
property is either h
(for hamdt
) or s
(for samdt
and supamdt
).
Amendment IDs are in the form of [amendment_type][number]-[congress].
updated_at
is the date and time that the JSON file was last saved. It reflects the time the scraper was run and is not metadata about the amendment itself.
An amendment can amend a bill, a treaty, or even another amendment.
Here is an example of the most common case:
{
"amends_amendment": null,
"amends_bill": {
"bill_id": "hr1947-113",
"bill_type": "hr",
"congress": 113,
"number": 1947
},
"amends_treaty": null
}
When the amendment amends a bill, you will see the amends_bill
property set and the amends_amendment
and amends_treaty
properties set to null. These fields correspond with the same fields in bills.
When an amendment amends another amendment, the amends_amendment
property is set to the other amendment's basic metadata. In addition, the amends_bill
or amends_treaty
(see below) property is set to the bill or treaty that is eventually amendment (it may be an amendment to an amendment to an amendment to a bill). Here is an example from H.Amdt. 10 in the 113th Congress:
{
"amends_amendment": {
"amendment_id": "hamdt5-113",
"amendment_type": "hamdt",
"congress": 113,
"number": 5
},
"amends_bill": {
"bill_id": "hr152-113",
"bill_type": "hr",
"congress": 113,
"number": 152
},
"amends_treaty": null
}
Finally, an amendment can also be proposed to amend a treaty, in which case amends_bill
will be null and amends_treaty
will include which treaty is being amended. Here is an example from S.Amdt. 3 in the 1000th Congress.
{
"amends_amendment": null,
"amends_bill": null,
"amends_treaty": {
"congress": 94,
"number": 25,
"treaty_id": "treaty25-94"
}
}
It may be possible for there to be an amendment to an amendment to a treaty, in which case amends_amendment
would not be null.
{
"description": "Amendment clarifies that Corps of Engineers construction projects receiving funds under this legislation will be at full Federal expense only with respect to the funds...",
"purpose": "An amendment numbered 6 printed in Part C of House Report 113-1 to clarify that the Corps of Engineers construction projects receiving funds in this legislation will be at..."
}
An amendment may have a description
or purpose
, both, or neither. These fields are copied over from similarly named fields on THOMAS. We do not know the semantic difference between the fields.
{
"sponsor": {
"bioguide_id": "W000437",
"district": null,
"name": "Wicker, Roger F.",
"state": "MS",
"title": "Sen",
"type": "person"
}
}
The sponsor of the amendment, if there is a sponsor, is set like in the example above. The bioguide_id
should be used to cross-reference with the congress-legislators YAML database. Historical data from GovTrack uses thomas_id
in place of bioguide_id
. See bills for more.
{
"introduced_at": "2013-04-24",
"proposed_at": "2013-04-24",
"status": "pass",
"status_at": "2013-05-06",
}
Every amendment has an introduced_at
date. The proper terminology seems to be that amendments are "offered" in the House and "submitted" in the Senate. We've normalized this difference to just introduced_at
for consistency with bills.
In the Senate, amendments also have a proposed date which is indicated with proposed_at
. We don't know what this means. This property is only set on Senate amendments.
status
can be one of offered
(meaning introduced), pass
(amendment was voted on and was accepted), fail
(amendment was voted on and failed), or withdrawn
(amendment was withdrawn). Our withdrawn detection needs some work. status_at
is the date or datetime timestamp when the status changed.
{
"actions": [
{
"acted_at": "2013-06-19T16:14:00-04:00",
"references": [
{
"reference": "CR H3862-3863",
"type": "consideration"
},
{
"reference": "CR H3862",
"type": "text"
}
],
"text": "Amendment (A008) offered by Mr. Graves (GA).",
"type": "action"
},
{
"acted_at": "2013-06-19T16:19:00-04:00",
"references": [
{
"reference": "CR H3863",
"type": "consideration"
}
],
"text": "By unanimous consent, the Graves (GA) amendment was withdrawn.",
"type": "action"
}
]
}
Amendments have actions
in the same format as bills.
The type
of an action can be either vote
or withdrawn
. When type
is vote
, the result
, how
, and roll
(for roll call votes) properties will be set and have the same meaning as in bills.