I am trying to access the values for each of the three Awards object under the 2nd "text" component in the below JSON using Java. I ultimately want to create objects with the information.
{
"searchApiFormatVersion": "1.0",
"searchName": "Details for Awards",
"description": "",
"totalRowCount": "3",
"returnedRowCount": "3",
"startingReturnedRowNumber": "1",
"basetype": "Project",
"columnCount": "2",
"columnHeaders": [
{
"text": "ID",
"dataType": "string",
"hierarchy": 1,
"parentName": "",
"isEntity": false,
"isEset": false
},
{
"text": "getPersonnelEffort()",
"dataType": "method",
"hierarchy": 2,
"parentName": "Custom Extension",
"isEntity": true,
"isEset": false
}
],
"resultSet": {
"rows": [
{
"values": [
{
"text": "A00000029",
"dataType": "string",
"columnHeader": "ID"
},
{
"text": "{\"id\":\"A00000029\",\"allocations\":[{\"AwardID\":\"A00000029\",\"AwardShortTitle\":\"SDH Proposal 001 Grants Capitation2\",\"AwardLongTitle\":\"SDH Proposal 001 Testing2\",\"DirectSponsorName\":\"University of Pennsylvania\",\"DirectSponsorID\":\"UPENN\",\"DirectsponsorAWDID\":\"UP010523\",\"PrimeSponsorName\":null,\"PrimeSponsorID\":null,\"PrimesponsorAWDID\":null,\"CFDA\":null,\"SponsorAwardDate\":null,\"AwardDepartmentID\":\"4011100\",\"AwardDepartmentName\":\"Neurobiology\",\"AwardStartDate\":\"2022-12-01T06:00:00Z\",\"AwardEndDate\":\"2025-11-30T06:00:00Z\",\"AwardProjectState\":\"Active\",\"AwardDateModified\":\"2023-01-10T20:16:01Z\",\"FinancialAccountName\":\"SDH Proposal 001 Grants Capitation2\",\"FinancialAccountResponsibleUnitID\":\"4011100\",\"FinancialAccountResponsibleUnitName\":\"Neurobiology\",\"FinancialAccountFund\":\"650\",\"FinancialAccountPeopleSoftProjectID\":\"60063974\",\"BudgetAllocationPeriodNumber\":1,\"BudgetAllocationIndirectRate\":60,\"BudgetAllocationStartDate\":\"2022-12-01T06:00:00Z\",\"BudgetAllocationEndDate\":\"2023-11-30T06:00:00Z\",\"Effort\":[]}]}",
"dataType": "method",
"columnHeader": "getPersonnelEffort()",
"oidPath": "com.webridge.entity.Entity[OID[A3B036D38D3B11ED8199285DAF565000]]"
}
]
},
{
"values": [
{
"text": "A00000034",
"dataType": "string",
"columnHeader": "ID"
},
{
"text": "{\"id\":\"A00000034\",\"allocations\":[{\"AwardID\":\"A00000034\",\"AwardShortTitle\":\"LC Test 01/04/23 - Non-Fed\",\"AwardLongTitle\":\"LC Test 01/04/2023 - Non-Fed\",\"DirectSponsorName\":\"23andMe, Inc.\",\"DirectSponsorID\":\"23ANDME\",\"DirectsponsorAWDID\":\"1234\",\"PrimeSponsorName\":null,\"PrimeSponsorID\":null,\"PrimesponsorAWDID\":null,\"CFDA\":null,\"SponsorAwardDate\":null,\"AwardDepartmentID\":\"5111200\",\"AwardDepartmentName\":\"Behavioral Medicine\",\"AwardStartDate\":\"2023-01-01T06:00:00Z\",\"AwardEndDate\":\"2026-01-31T06:00:00Z\",\"AwardProjectState\":\"Active\",\"AwardDateModified\":\"2023-01-10T16:16:40Z\",\"FinancialAccountName\":\"LC Test 01/04/23 - Non-Fed\",\"FinancialAccountResponsibleUnitID\":\"5111200\",\"FinancialAccountResponsibleUnitName\":\"Behavioral Medicine\",\"FinancialAccountFund\":\"610\",\"FinancialAccountPeopleSoftProjectID\":null,\"BudgetAllocationPeriodNumber\":1,\"BudgetAllocationIndirectRate\":70.54679870605469,\"BudgetAllocationStartDate\":\"2023-02-01T06:00:00Z\",\"BudgetAllocationEndDate\":\"2024-01-31T06:00:00Z\",\"Effort\":[{\"AcademicMonthsEffort\":2,\"AcademicMonthsSalaryRequested\":1,\"CalendarMonthsRequested\":1,\"CalendarMonthsEffort\":2,\"CalendarCostShareMonths\":1,\"CalendarCostShareSalaryRequestedPercent\":0.07999999821186065,\"CalendarEffortPercent\":0.17000000178813934,\"SummerMonthsEffort\":null,\"SummerMonthsSalaryRequested\":null,\"DistributeEffort\":false,\"PersonnelRole\":\"PD/PI\",\"PersonFirstName\":\"Leah\",\"PersonLastName\":\"Aberman\",\"PersonEmployeeID\":\"3247211\",\"PersonAppointmentType\":12,\"PersonStartDate\":\"2023-02-01T06:00:00Z\",\"PersonEndDate\":\"2024-01-31T06:00:00Z\"}]},{\"AwardID\":\"A00000034\",\"AwardShortTitle\":\"LC Test 01/04/23 - Non-Fed\",\"AwardLongTitle\":\"LC Test 01/04/2023 - Non-Fed\",\"DirectSponsorName\":\"23andMe, Inc.\",\"DirectSponsorID\":\"23ANDME\",\"DirectsponsorAWDID\":\"1234\",\"PrimeSponsorName\":null,\"PrimeSponsorID\":null,\"PrimesponsorAWDID\":null,\"CFDA\":null,\"SponsorAwardDate\":null,\"AwardDepartmentID\":\"5111200\",\"AwardDepartmentName\":\"Behavioral Medicine\",\"AwardStartDate\":\"2023-01-01T06:00:00Z\",\"AwardEndDate\":\"2026-01-31T06:00:00Z\",\"AwardProjectState\":\"Active\",\"AwardDateModified\":\"2023-01-10T16:16:40Z\",\"FinancialAccountName\":\"LC Test 01/04/23 - Non-Fed\",\"FinancialAccountResponsibleUnitID\":\"5111200\",\"FinancialAccountResponsibleUnitName\":\"Behavioral Medicine\",\"FinancialAccountFund\":\"610\",\"FinancialAccountPeopleSoftProjectID\":null,\"BudgetAllocationPeriodNumber\":3,\"BudgetAllocationIndirectRate\":72,\"BudgetAllocationStartDate\":\"2025-02-01T06:00:00Z\",\"BudgetAllocationEndDate\":\"2026-01-31T06:00:00Z\",\"Effort\":[{\"AcademicMonthsEffort\":12,\"AcademicMonthsSalaryRequested\":11,\"CalendarMonthsRequested\":11,\"CalendarMonthsEffort\":12,\"CalendarCostShareMonths\":1,\"CalendarCostShareSalaryRequestedPercent\":0.07999999821186065,\"CalendarEffortPercent\":1,\"SummerMonthsEffort\":null,\"SummerMonthsSalaryRequested\":null,\"DistributeEffort\":false,\"PersonnelRole\":\"PD/PI\",\"PersonFirstName\":\"Leah\",\"PersonLastName\":\"Aberman\",\"PersonEmployeeID\":\"3247211\",\"PersonAppointmentType\":12,\"PersonStartDate\":\"2025-02-01T06:00:00Z\",\"PersonEndDate\":\"2026-01-31T06:00:00Z\"}]}]}",
"dataType": "method",
"columnHeader": "getPersonnelEffort()",
"oidPath": "com.webridge.entity.Entity[OID[E0E466FA8DEA11ED8199285DAF565000]]"
}
]
},
{
"values": [
{
"text": "A00000040",
"dataType": "string",
"columnHeader": "ID"
},
{
"text": "{\"id\":\"A00000040\",\"allocations\":[{\"AwardID\":\"A00000040\",\"AwardShortTitle\":\"KSA0109 DOD CS\",\"AwardLongTitle\":\"KSA0109 DOD CS long title\",\"DirectSponsorName\":\"Air Force Office of Scientific Research\",\"DirectSponsorID\":\"AFOSR\",\"DirectsponsorAWDID\":\"AFOSR0109ABC\",\"PrimeSponsorName\":null,\"PrimeSponsorID\":null,\"PrimesponsorAWDID\":null,\"CFDA\":\"12.431\",\"SponsorAwardDate\":null,\"AwardDepartmentID\":\"40115001\",\"AwardDepartmentName\":\"Physics & Astronomy\",\"AwardStartDate\":\"2023-02-01T06:00:00Z\",\"AwardEndDate\":\"2026-01-31T06:00:00Z\",\"AwardProjectState\":\"Active\",\"AwardDateModified\":\"2023-01-10T21:59:43Z\",\"FinancialAccountName\":\"KSA01091 DOD CS\",\"FinancialAccountResponsibleUnitID\":\"40115001\",\"FinancialAccountResponsibleUnitName\":\"Physics & Astronomy\",\"FinancialAccountFund\":\"610\",\"FinancialAccountPeopleSoftProjectID\":\"60063981\",\"BudgetAllocationPeriodNumber\":1,\"BudgetAllocationIndirectRate\":0,\"BudgetAllocationStartDate\":\"2023-02-01T06:00:00Z\",\"BudgetAllocationEndDate\":\"2024-01-31T06:00:00Z\",\"Effort\":[]},{\"AwardID\":\"A00000040\",\"AwardShortTitle\":\"KSA0109 DOD CS\",\"AwardLongTitle\":\"KSA0109 DOD CS long title\",\"DirectSponsorName\":\"Air Force Office of Scientific Research\",\"DirectSponsorID\":\"AFOSR\",\"DirectsponsorAWDID\":\"AFOSR0109A\",\"PrimeSponsorName\":null,\"PrimeSponsorID\":null,\"PrimesponsorAWDID\":null,\"CFDA\":\"12.431\",\"SponsorAwardDate\":null,\"AwardDepartmentID\":\"4011500\",\"AwardDepartmentName\":\"Physics & Astronomy\",\"AwardStartDate\":\"2023-02-01T06:00:00Z\",\"AwardEndDate\":\"2026-01-31T06:00:00Z\",\"AwardProjectState\":\"Active\",\"AwardDateModified\":\"2023-01-10T21:59:43Z\",\"FinancialAccountName\":\"KSA0109 DOD CS\",\"FinancialAccountResponsibleUnitID\":\"4011500\",\"FinancialAccountResponsibleUnitName\":\"Physics & Astronomy\",\"FinancialAccountFund\":\"610\",\"FinancialAccountPeopleSoftProjectID\":\"60063981\",\"BudgetAllocationPeriodNumber\":1,\"BudgetAllocationIndirectRate\":60,\"BudgetAllocationStartDate\":\"2023-02-01T06:00:00Z\",\"BudgetAllocationEndDate\":\"2024-01-31T06:00:00Z\",\"Effort\":[]}]}",
"dataType": "method",
"columnHeader": "getPersonnelEffort()",
"oidPath": "com.webridge.entity.Entity[OID[A07BF574903C11ED8199285DAF565000]]"
}
]
}
]
}
}
I'm using Jayway JsonPath syntax to access it and can get down to the text component using the code below.
String jsonPath = "$." + "resultSet" + "." + "rows" + ".." + "text";
String response = JsonPath.read(stringJsonResponse, jsonPath).toString();
logger.info("Response: " + response);
When I try something like the below, I get an empty response. Would anyone know how to dig down deeper?
String jsonPath = "$." + "resultSet" + "." + "rows" + ".." + "text" + ".." + "AwardID;