我需要从这种字符串中获取“付款类型和客户类型
Examples:
| market | payment type | customer type | translation |
| NZ | AAA | BBB | NZ |
| AZ | CCC | DDD | AZ |
| CA | EEE | FFF | CA |
我应该尝试获取模式并为此编写函数吗?或者我可以找到一些库来检测它
所以输出应该是 {付款:[“ AAA”,“ CCC”,“ EEE”], 客户:[“ BBB”,'DDD“,” FFF“]}
function detect(str){
let countBar=1
let countBar2=0
let paymentLoc=NaN
let customerLoc=NaN
let after =0
let arr1=str.split(" ")
arr1=arr1.filter(item=>{return item!==""})
let newStr=''
for(let i=0;i<arr1.length;i++){
arr1[i].trim()
if(arr1[i]==='|'){
countBar++
}
if(arr1[i]==="||"){
countBar2++
}
if(arr1[i].includes("payment")){
paymentLoc=i
}
after=((countBar/(countBar2))-1)*2
let sol=[]
for(let i=0;i<arr1.length;i++){
if(arr1[i].includes("payment")){
console.log('payment index',i)
sol.push(arr1[i+after+1])
}
if(arr1[i].includes("customer")){
console.log('customer index',i)
sol.push(arr1[i+after+1])
}
}
newStr=arr1.join('')
console.log(newStr)
}
答案 0 :(得分:0)
我玩得很开心。我首先想到的是使用npm包,因为该字符串看起来很像CSV,带有|
作为分隔符。 csvtojson软件包是一个很好的软件包,但是当您可以一起破解某些东西时,为什么要使用一个备受赞誉的库呢?
这是我的第一次尝试(在打字稿中):
const exampleString = ` | market | payment type | customer type | translation |
| NZ | AAA | BBB | NZ |
| AZ | CCC | DDD | AZ |
| CA | EEE | FFF | CA |`;
const cleanColumn = (col: string) =>
col
.replace("|", "")
.trim()
.replace(/\s/, "_");
const cleanRow = (row: string) =>
row
.split(/\s\|/)
.map(cleanColumn)
.filter(Boolean);
const pivotRows = (
pivoted: string[][],
currentRow: string[],
rowIndex: number
) => {
if (rowIndex === 0) {
currentRow.forEach((col, colIndex) => {
pivoted[colIndex] = [col];
});
} else {
currentRow.forEach((col, colIndex) => {
pivoted[colIndex].push(col);
});
}
return pivoted;
};
const buildObject = (
obj: { [key: string]: string[] },
currentRow: string[]
) => {
let currentCol: string;
currentRow.forEach((col, index) => {
if (index === 0) {
currentCol = col;
obj[currentCol] = [];
} else {
obj[currentCol].push(col);
}
});
return obj;
};
const detect = (str: string) =>
str
.split("\n")
.map(cleanRow)
.reduce(pivotRows, [])
.reduce(buildObject, {});
console.log(detect(exampleString));
如果您查看detect
,它只是在字符串上执行一系列函数。第一个只是通过换行符将其拆分。我喜欢使用countBar
变量来实现的目的,但这似乎更容易。
这给了我们一堆字符串数组,需要将其分解为列。在这里,我使用了一些RegEx来分隔space
和|
组合之间的所有内容。在cleanColumn()
中,如果有散乱符,我将删除其余的|
,然后用下划线替换空格,以便将它们用作对象键。
然后,使用.filter(Boolean)
技巧(link)删除空字符串。最后两个函数可能比必要的更为冗长,但是它们可以完成工作。 pivotRows()
使用行和列索引将列旋转为行。最后,在buildObject()
中,每行的第一个元素被添加为对象的键,其余的值被推入字符串数组。
真的,您应该只使用csvtojson
。