텍스트 파일의 문장들을 파싱하여 변경하는 것이 어렵네요

[ AAA ] xxx = yyy = zzz = xxx = yyy = zzz = [ BBB ] xxx = yyy = zzz = xxx = yyy = zzz = [ BBB ] xxx = yyy = zzz = xxx = yyy = zzz = [ CCC ] xxx = yyy = zzz = xxx = yyy = zzz =
위와 같은 포맷의 데이터를 저장하고 있는 파일이 있습니다
동일한 키워드가 2개 이상이기 때문에 키워드로 파싱하기에는 좋은 포맷이 아니라고 생각하지만 제가 권한이 없어서 포맷 자체를 바꿀 수는 없습니다
저는 위에서부터 두번째 [ BBB ] 섹션에 있는
첫번째 xxx 값, 첫번째 yyy 값, 첫번째 zzz 값, 두번째 xxx 값, 두번째 yyy 값, 두번째 zzz 값을
그때그때 변경해주어야 하는데
몇 번째 xxx를 변경해주어야 하는지는 매개변수로 받아서 결정됩니다
여기서 위에서부터 두번째 [ BBB ]를 찾아서
다음에 나오는 첫번째 혹은 두번째 xxx 값을 변경해주는 것이 쉽지 않습니다
이전에는 awk를 이용하여 " = "이 없는 라인을 레코드로 정의하고
" = "이 있는 라인을 필드로 정의하여
세번째 레코드의 첫번째 xxx 필드, 두번째 xxx 필드라고 파싱하여 변경해주었고
이 방법은 제대로 동작했습니다
그런데 [ DDD ], [ EEE ], [ FFF ] 등이 중간중간에 추가되어서
이전의 세번째 레코드가 아닌, n번째 레코드라고 그때그때 변경해주어야 하여
위의 방법으로는 더이상 파싱하여 변경할 수 없어졌습니다
중간중간에 [ DDD ], [ EEE ], [ FFF ] 등이 추가되더라도
"[ BBB ]" 문자열 자체는 항상 고정되기 때문에
위에서부터 두번째 "[ BBB ]"를 파싱한 후
다음에 나오는 첫번째 xxx를 찾아서 (예를 들어 넘어온 매개변수가 31이라면)
xxx = 31 과 같이 변경해주는 방법으로 구현하면 되는데
awk, sed, python만! 사용가능합니다
다시 정리하면, 두번째 "[ BBB ]" 문자열을 파싱하여
(매개변수에 따라) 다음에 나오는 첫번째 xxx나 두번째 xxx를 찾아서
(또하나의 매개변수에 따라) 그 값을 xxx = 31과 같이 변경하는 방법입니다
방법은 반드시 이와 같은 방법으로 변경해야 하고
다른 방법을 생각하셨다면 제가 설명을 부족하게 하여 제 설명을 이해 못하신 것입니다
이에 대해서는 양해 부탁드립니다
답변이나 도움 말씀 주시면 감사하겠습니다
댓글 달기