const regex = /date_modified(?<date_modified>(?:.*?\n?)*?)internal_id(?<internal_id>(?:.*?\n?)*?)task(?<task>(?:.*?\n?)*?)priority(?<priority>(?:.*?\n?)*?)status(?<status>(?:.*?\n?)*?)task_status(?<task_status>(?:.*?\n?)*?)created(?<created>(?:.*?\n?)*?)assigned(?<assigned>(?:.*?\n?)*?)date_created(?<date_created>(?:.*?\n?)*?)date_started(?<date_started>(?:.*?\n?)*?)date_due(?<date_due>(?:.*?\n?)*?)date_completed(?<date_completed>(?:.*?\n?)*?)bunit(?<bunit>(?:.*?\n?)*?)task_vendor(?<task_vendor>(?:.*?\n?)*?)task_category(?<task_category>(?:.*?\n?)*?)customer(?<customer>(?:.*?\n?)*?)cust_name(?<cust_name>(?:.*?\n?)*?)cust_territory(?<cust_territory>(?:.*?\n?)*?)contact(?<contact>(?:.*?\n?)*?)time_date(?<time_date>(?:.*?\n?)*?)time_duration(?<time_duration>(?:.*?\n?)*?)comment(?<comment>(?:.*?\n?)*?)opportunity(?<opportunity>(?:.*?\n?)*?)opp_status(?<opp_status>(?:.*?\n?)*?)opp_engineer(?<opp_engineer>(?:.*?\n?)*?)transaction(?<transaction>(?:.*?\n?)*?)yeg_id(?<yeg_id>(?:.*?\n?)*?)Recent Changes/gm;
// Alternative syntax using RegExp constructor
// const regex = new RegExp('date_modified(?<date_modified>(?:.*?\\n?)*?)internal_id(?<internal_id>(?:.*?\\n?)*?)task(?<task>(?:.*?\\n?)*?)priority(?<priority>(?:.*?\\n?)*?)status(?<status>(?:.*?\\n?)*?)task_status(?<task_status>(?:.*?\\n?)*?)created(?<created>(?:.*?\\n?)*?)assigned(?<assigned>(?:.*?\\n?)*?)date_created(?<date_created>(?:.*?\\n?)*?)date_started(?<date_started>(?:.*?\\n?)*?)date_due(?<date_due>(?:.*?\\n?)*?)date_completed(?<date_completed>(?:.*?\\n?)*?)bunit(?<bunit>(?:.*?\\n?)*?)task_vendor(?<task_vendor>(?:.*?\\n?)*?)task_category(?<task_category>(?:.*?\\n?)*?)customer(?<customer>(?:.*?\\n?)*?)cust_name(?<cust_name>(?:.*?\\n?)*?)cust_territory(?<cust_territory>(?:.*?\\n?)*?)contact(?<contact>(?:.*?\\n?)*?)time_date(?<time_date>(?:.*?\\n?)*?)time_duration(?<time_duration>(?:.*?\\n?)*?)comment(?<comment>(?:.*?\\n?)*?)opportunity(?<opportunity>(?:.*?\\n?)*?)opp_status(?<opp_status>(?:.*?\\n?)*?)opp_engineer(?<opp_engineer>(?:.*?\\n?)*?)transaction(?<transaction>(?:.*?\\n?)*?)yeg_id(?<yeg_id>(?:.*?\\n?)*?)Recent Changes', 'gm')
const str = `date_modified21-DECEMBER-2020 12:25 PMinternal_id313017task2nd Year Annual
billing pricing -34515priorityMediumstatusCompletedtask_statusAllocatedcreated
Bernadine PereraassignedBernadine Pereradate_created21-DECEMBER-2020 12:25 PM
date_started21-DECEMBER-2020date_due21-DECEMBER-2020date_completed
21-DECEMBER-2020bunitOperationstask_vendorSplunktask_categoryOthercustomer
cust_namecust_territorycontacttime_datetime_durationcommentopportunityopp_status
opp_engineertransaction yeg_idRecent Changes
DateSet byContextTypeFieldOld ValueNew Value21-DECEMBER-2020 12:25 PMBernadine
PereraUISetStart Date21-DECEMBER-2020 12:00 Utc21-DECEMBER-2020 12:25 PM
Bernadine PereraUISetOwnerBernadine Perera21-DECEMBER-2020 12:25 PMBernadine
PereraUISetAssignedBernadine Perera21-DECEMBER-2020 12:25 PMBernadine PereraUI
SetBusiness UnitOperations21-DECEMBER-2020 12:25 PMBernadine PereraUISetTask
CategoryOther21-DECEMBER-2020 12:25 PMBernadine PereraUISetTask StateAllocated
21-DECEMBER-2020 12:25 PMBernadine PereraUISetTask VendorSplunk21-DECEMBER-2020
12:25 PMBernadine PereraUICreateRecordTASK313017You requested to receive an
email alert for this record. Click here to modify your email alerts
[https://55349.app.netsuite.com/app/center/userprefs.nl?sc=-29&selectedtab=alerts]`;
// Reset `lastIndex` if this regex is defined globally
// regex.lastIndex = 0;
let m;
while ((m = regex.exec(str)) !== null) {
// This is necessary to avoid infinite loops with zero-width matches
if (m.index === regex.lastIndex) {
regex.lastIndex++;
}
// The result can be accessed through the `m`-variable.
m.forEach((match, groupIndex) => {
console.log(`Found match, group ${groupIndex}: ${match}`);
});
}
Please keep in mind that these code samples are automatically generated and are not guaranteed to work. If you find any syntax errors, feel free to submit a bug report. For a full regex reference for JavaScript, please visit: https://developer.mozilla.org/en/docs/Web/JavaScript/Guide/Regular_Expressions