我必须订购
("Forecast":["WP17 - CO746U100 - Wenceslao Escalante --- Telefonia - Implementaciones","WP19 - CO804U100 - Viamonte Nuevo --- Telefonia - Implementaciones","WP18 - CO663U200 - Corral de Bustos 2 --- Telefonia - Implementaciones","WP22 - MBA205 - Olavarria 2 --- Telefonia - Integraciones","WP23 - MC1165 - Martinez 4 --- Telefonia - Integraciones","WP26 - MC1881 - Bajo Flores 2 --- Telefonia - Integraciones","WP12 - FD454 - Shopping Mendoza --- Telefonia - Implementaciones","WP65 - TEST1 - TEST-TASK --- Telefonia - Integraciones","WP25 - MC1510 - Nunez 4 Av Congreso --- Telefonia - Integraciones","WP1 - UFO555 - Villa Maria --- Telefonia - Implementaciones","WP28 - MFO066 - CAC Formosa --- Telefonia - Integraciones","WP70 - 4312341 - sarasa --- Telefonia - Integraciones","WP71 - 54325 - sarasa2 --- Telefonia - Integraciones","WP75 - 00001 - Complejo Capitalinas --- Obras Civiles","WP76 - 00002 - Mejora de la Ca\u00f1ada --- Obras Civiles","WP32 - MCO800 - Unquillo Norte Nuevo --- Telefonia - Implementaciones","WP33 - MCO817 - Hospital Privado Nuevo --- Telefonia - Implementaciones","WP34 - LTF039 - Ushuaia Paseo del Fuego --- Telefonia - Implementaciones","WP36 - LSJ062 - San Juan UMTS 2 --- Telefonia - Implementaciones","WP37 - LCO261 - ZIPOLI NUEVO --- Telefonia - Implementaciones","WP63 - 7878 - SIAM SA --- Telefonia - Implementaciones","WP64 - MCF162 - Kansas Acassuso Test --- Telefonia - Implementaciones","WP69 - 11111 - Nueva Tare --- Telefonia - Implementaciones"],)
正如所说的那样,有工具,积分和欧普拉。
代码:
let ObrasV = []
let ImplementacionesV = []
let IntegracionesV = []
if(this.state.dataSource){
this.state.dataSource.forEach(function(DATA) {
if(/^Integraciones/.test(DATA)) {
IntegracionesV = IntegracionesV.concat(DATA)
}
if(/^Implementaciones/.test(DATA)) {
ImplementacionesV = ImplementacionesV.concat(DATA)
}
if(/^Obras/.test(DATA)) {
ObrasV = ObrasV.concat(DATA)
}
})
this.setState({
Integraciones: IntegracionesV,
Implementaciones: ImplementacionesV,
Obras: ObrasV,
})
}
我是新来的,所以我会尽我所能?
答案 0 :(得分:1)
您可以混合使用reduce
,filter
和includes
来实现它
const data = ["WP17 - CO746U100 - Wenceslao Escalante --- Telefonia - Implementaciones", "WP19 - CO804U100 - Viamonte Nuevo --- Telefonia - Implementaciones", "WP18 - CO663U200 - Corral de Bustos 2 --- Telefonia - Implementaciones", "WP22 - MBA205 - Olavarria 2 --- Telefonia - Integraciones", "WP23 - MC1165 - Martinez 4 --- Telefonia - Integraciones", "WP26 - MC1881 - Bajo Flores 2 --- Telefonia - Integraciones", "WP12 - FD454 - Shopping Mendoza --- Telefonia - Implementaciones", "WP65 - TEST1 - TEST-TASK --- Telefonia - Integraciones", "WP25 - MC1510 - Nunez 4 Av Congreso --- Telefonia - Integraciones", "WP1 - UFO555 - Villa Maria --- Telefonia - Implementaciones", "WP28 - MFO066 - CAC Formosa --- Telefonia - Integraciones", "WP70 - 4312341 - sarasa --- Telefonia - Integraciones", "WP71 - 54325 - sarasa2 --- Telefonia - Integraciones", "WP75 - 00001 - Complejo Capitalinas --- Obras Civiles", "WP76 - 00002 - Mejora de la Ca\u00f1ada --- Obras Civiles", "WP32 - MCO800 - Unquillo Norte Nuevo --- Telefonia - Implementaciones", "WP33 - MCO817 - Hospital Privado Nuevo --- Telefonia - Implementaciones", "WP34 - LTF039 - Ushuaia Paseo del Fuego --- Telefonia - Implementaciones", "WP36 - LSJ062 - San Juan UMTS 2 --- Telefonia - Implementaciones", "WP37 - LCO261 - ZIPOLI NUEVO --- Telefonia - Implementaciones", "WP63 - 7878 - SIAM SA --- Telefonia - Implementaciones", "WP64 - MCF162 - Kansas Acassuso Test --- Telefonia - Implementaciones", "WP69 - 11111 - Nueva Tare --- Telefonia - Implementaciones"]
const result = ['Implementaciones', 'Integraciones', 'Obras']
.reduce((total, category) => ({
...total,
[category]: data.filter(line => line.includes(category))
}), {})
console.log(result)
结果对象将包含3个包含所有数据的数组
使用forEach
易于阅读的实现:
const data = ["WP17 - CO746U100 - Wenceslao Escalante --- Telefonia - Implementaciones", "WP19 - CO804U100 - Viamonte Nuevo --- Telefonia - Implementaciones", "WP18 - CO663U200 - Corral de Bustos 2 --- Telefonia - Implementaciones", "WP22 - MBA205 - Olavarria 2 --- Telefonia - Integraciones", "WP23 - MC1165 - Martinez 4 --- Telefonia - Integraciones", "WP26 - MC1881 - Bajo Flores 2 --- Telefonia - Integraciones", "WP12 - FD454 - Shopping Mendoza --- Telefonia - Implementaciones", "WP65 - TEST1 - TEST-TASK --- Telefonia - Integraciones", "WP25 - MC1510 - Nunez 4 Av Congreso --- Telefonia - Integraciones", "WP1 - UFO555 - Villa Maria --- Telefonia - Implementaciones", "WP28 - MFO066 - CAC Formosa --- Telefonia - Integraciones", "WP70 - 4312341 - sarasa --- Telefonia - Integraciones", "WP71 - 54325 - sarasa2 --- Telefonia - Integraciones", "WP75 - 00001 - Complejo Capitalinas --- Obras Civiles", "WP76 - 00002 - Mejora de la Ca\u00f1ada --- Obras Civiles", "WP32 - MCO800 - Unquillo Norte Nuevo --- Telefonia - Implementaciones", "WP33 - MCO817 - Hospital Privado Nuevo --- Telefonia - Implementaciones", "WP34 - LTF039 - Ushuaia Paseo del Fuego --- Telefonia - Implementaciones", "WP36 - LSJ062 - San Juan UMTS 2 --- Telefonia - Implementaciones", "WP37 - LCO261 - ZIPOLI NUEVO --- Telefonia - Implementaciones", "WP63 - 7878 - SIAM SA --- Telefonia - Implementaciones", "WP64 - MCF162 - Kansas Acassuso Test --- Telefonia - Implementaciones", "WP69 - 11111 - Nueva Tare --- Telefonia - Implementaciones"]
const result = {};
['Implementaciones', 'Integraciones', 'Obras'].forEach(category => {
result[category] = data.filter(line => line.includes(category))
})
console.log(result)
答案 1 :(得分:0)
只需注意new RegExp()
并避免使用^
let ObrasV = []
let ImplementacionesV = []
let IntegracionesV = []
if(this.state.dataSource){
this.state.dataSource.forEach(function(DATA) {
if(new RegExp(/Integraciones/).test(DATA)) {
IntegracionesV = IntegracionesV.concat(DATA)
}
if(new RegExp(/Implementaciones/).test(DATA)) {
ImplementacionesV = ImplementacionesV.concat(DATA)
}
if(new RegExp(/Obras/).test(DATA)) {
ObrasV = ObrasV.concat(DATA)
}
})
this.setState({
Integraciones: IntegracionesV,
Implementaciones: ImplementacionesV,
Obras: ObrasV,
})
}