如何从这种字符串中获取关键字

时间:2019-04-18 21:42:09

标签: javascript

我需要从这种字符串中获取“付款类型和客户类型

   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)


}

1 个答案:

答案 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