sed, um das erste Vorkommen eines Musters zu finden, NACHDEM ein anderes Muster gefunden wurde

sed, um das erste Vorkommen eines Musters zu finden, NACHDEM ein anderes Muster gefunden wurde

Gibt es eine Möglichkeit, dem ersten Vorkommen einer Codezeile NUR nach dem Vorkommen eines anderen Musters etwas voranzustellen? Ich möchte die Zeile addTween (durch Voranstellen eines Kommentars mit doppeltem Schrägstrich) NUR für „Group2“ deaktivieren, das durch einen automatisch generierten Kommentar „// Group2“ abgegrenzt ist. Mit anderen Worten, ich möchte

  1. Suche nach dem Vorkommen von "// Group2"
  2. Verwenden Sie sed, um der Zeile „addTween“ nur für Gruppe2 einen Kommentar voranzustellen.

Eingabedatei:

// Group1
this.shape = new cjs.Shape();
this.shape.graphics.f().s("#663300").ss(1,1,1).p("EBHXAAAQAAW105QIQ06QJ9kAAQ9jAA05wJQ06wIAA21QAA2zU6wJQU5wIdjAAQdkAAU6QIQU5QJAAWzg");
this.shape.setTransform(1005.55,596.9);

this.shape_1 = new cjs.Shape();
this.shape_1.graphics.f("#E5CCFF").s().p("EgydAm9Q05wJAA20QAA2zU5wJQU6wIdjgBQdkABU5QIQU6QJAAWzQAAW006QJQ05QJ9kgBQ9jAB06wJg");
this.shape_1.setTransform(1005.55,596.9);

this.timeline.addTween(cjs.Tween.get({}).to({state:[{t:this.shape_1},{t:this.shape}]}).wait(1));

// Group2
this.shape_2 = new cjs.Shape();
this.shape_2.graphics.f().s("#666600").ss(44.3,1,1).p("EhDmgf6MCHNAAAMAAAA/1MiHNAAAg");
this.shape_2.setTransform(833.25,400.65);

this.shape_3 = new cjs.Shape();
this.shape_3.graphics.f("#336699").s().p("EhDmAf7MAAAg/1MCHNAAAMAAAA/1g");
this.shape_3.setTransform(833.25,400.65);

this.timeline.addTween(cjs.Tween.get({}).to({state:[{t:this.shape_3},{t:this.shape_2}]}).wait(1));

Ausgabedatei: (beachten Sie, dass die einzige Änderung darin besteht, dass der letzten Zeile ein doppelter Kommentarschrägstrich vorangestellt wurde)

// Group1

this.shape = new cjs.Shape();
this.shape.graphics.f().s("#663300").ss(1,1,1).p("EBHXAAAQAAW105QIQ06QJ9kAAQ9jAA05wJQ06wIAA21QAA2zU6wJQU5wIdjAAQdkAAU6QIQU5QJAAWzg");
this.shape.setTransform(1005.55,596.9);

this.shape_1 = new cjs.Shape();
this.shape_1.graphics.f("#E5CCFF").s().p("EgydAm9Q05wJAA20QAA2zU5wJQU6wIdjgBQdkABU5QIQU6QJAAWzQAAW006QJQ05QJ9kgBQ9jAB06wJg");
this.shape_1.setTransform(1005.55,596.9);

this.timeline.addTween(cjs.Tween.get({}).to({state:[{t:this.shape_1},{t:this.shape}]}).wait(1));

// Group2

this.shape_2 = new cjs.Shape();
this.shape_2.graphics.f().s("#666600").ss(44.3,1,1).p("EhDmgf6MCHNAAAMAAAA/1MiHNAAAg");
this.shape_2.setTransform(833.25,400.65);

this.shape_3 = new cjs.Shape();
this.shape_3.graphics.f("#336699").s().p("EhDmAf7MAAAg/1MCHNAAAMAAAA/1g");
this.shape_3.setTransform(833.25,400.65);

//this.timeline.addTween(cjs.Tween.get({}).to({state:[{t:this.shape_3},{t:this.shape_2}]}).wait(1));

Antwort1

sed '/\/\/ Group2/,/addTween/ s/^.*addTween/\/\/&/' file

Dadurch wird der Text zwischen // Group2und dem Folgenden gesucht addTweenund //der Zeile, die enthält, hinzugefügt addTween.

verwandte Informationen