비슷한 질문이 있지만 내가 겪고 있는 문제를 완전히 해결하는 것은 없습니다.
간단히 말해서, 찾고 있는 문자열이 포함된 모든 블록을 인쇄해야 합니다. 각 블록의 시작 줄에는 다음이 포함됩니다. <항목 버전=
자세한 내용은 아래를 참조하세요.
패턴 영역(블록) 내에서 특정 문자열이 인식되면 패턴 사이의 전체 영역(블록)을 인쇄하는 대용량 파일(수십만 라인)을 검색하고 싶습니다.
다음을 사용하여 패턴 사이의 전체 영역을 인쇄할 수 있다는 것을 알고 있습니다. 여기서 이러한 블록의 시작 및 끝 식별자는 "/<entry version="입니다.
awk '/<entry version=/{flag=1} flag; /<entry version=/{flag=0}'
하지만 이러한 패턴 사이에 특정 문자열이 발견되면 전체 블록을 인쇄하도록 하려면 어떻게 해야 합니까?
청크 영역의 경우 실제 데이터의 가장 짧은 부분은 다음과 같습니다(각 청크의 길이는 실제로 수천 줄임에도 불구하고). 제가 사용할 수 있는 더 나은 예를 함께 만들어준 Terdon에게 감사를 표하고 싶습니다.
<entry version="21.1" url="http://v21.proteinatlas.org/ENSG00000000003">
<name>TSPAN6</name>
<synonym>T245</synonym>
<synonym>TM4SF6</synonym>
<synonym>TSPAN-6</synonym>
<identifier id="ENSG00000000003" db="Ensembl" version="103.38" assembly="GRCh38.p13" gencodeVersion="37">
<xref id="O43657" db="Uniprot/SWISSPROT"/>
<xref id="7105" db="NCBI GeneID"/>
</identifier>
<proteinClasses>
<proteinClass source="MDM" id="Ma" parent_id="" name="Predicted membrane proteins"/>
위의 실제 형식에서는 특정 문자열의 이름과 동의어를 확인하므로 "TSPAN6"을 찾으면 해당 블록이 인쇄됩니다. 각 블록에는 수천 개의 줄이 있으므로 아래는 블록 내 문자열 일치를 기반으로 블록을 인쇄하는 방법을 구성한 미니 버전입니다.
다음은 문자열이 "MEMSAT" 및 "TNMD"
입력 예인 경우의 예입니다.
<entry version="21.1" url="http://v21.proteinatlas.org/ENSG00000000003">
<name>TSPAN6</name>
<synonym>T245</synonym>
<synonym>TM4SF6</synonym>
<synonym>TSPAN-6</synonym>
<identifier id="ENSG00000000003" db="Ensembl" version="103.38" assembly="GRCh38.p13" gencodeVersion="37">
<xref id="O43657" db="Uniprot/SWISSPROT"/>
<xref id="7105" db="NCBI GeneID"/>
</identifier>
<proteinClasses>
<proteinClass source="MDM" id="Ma" parent_id="" name="Predicted membrane proteins"/>
<proteinClass source="Ezkurdia et al 2014" id="Eb" parent_id="" name="Protein evidence (Ezkurdia et al 2014)"/>
</proteinClasses>
<proteinEvidence evidence="Evidence at protein level">
<evidence source="HPA" evidence="Evidence at transcript level"/>
<evidence source="MS" evidence="Not available"/>
<evidence source="UniProt" evidence="Evidence at protein level"/>
</proteinEvidence>
</entry>
<entry version="21.1" url="http://v21.proteinatlas.org/ENSG00000000005">
<name>TNMD</name>
<synonym>BRICD4</synonym>
<synonym>ChM1L</synonym>
<synonym>myodulin</synonym>
<synonym>TEM</synonym>
<synonym>tendin</synonym>
<identifier id="ENSG00000000005" db="Ensembl" version="103.38" assembly="GRCh38.p13" gencodeVersion="37">
<xref id="Q9H2S6" db="Uniprot/SWISSPROT"/>
<xref id="64102" db="NCBI GeneID"/>
</identifier>
<proteinClasses>
<proteinClass source="MDM" id="Ma" parent_id="" name="Predicted membrane proteins"/>
<proteinClass source="MDM" id="Md" parent_id="" name="Membrane proteins predicted by MDM"/>
<proteinClass source="MEMSAT3" id="Me" parent_id="" name="MEMSAT3 predicted membrane proteins"/>
</proteinClasses>
<proteinEvidence evidence="Evidence at protein level">
<evidence source="HPA" evidence="Evidence at transcript level"/>
<evidence source="MS" evidence="Not available"/>
<evidence source="UniProt" evidence="Evidence at protein level"/>
</proteinEvidence>
</entry>
출력 예:
<entry version="21.1" url="http://v21.proteinatlas.org/ENSG00000000005">
<name>TNMD</name>
<synonym>BRICD4</synonym>
<synonym>ChM1L</synonym>
<synonym>myodulin</synonym>
<synonym>TEM</synonym>
<synonym>tendin</synonym>
<identifier id="ENSG00000000005" db="Ensembl" version="103.38" assembly="GRCh38.p13" gencodeVersion="37">
<xref id="Q9H2S6" db="Uniprot/SWISSPROT"/>
<xref id="64102" db="NCBI GeneID"/>
</identifier>
<proteinClasses>
<proteinClass source="MDM" id="Ma" parent_id="" name="Predicted membrane proteins"/>
<proteinClass source="MDM" id="Md" parent_id="" name="Membrane proteins predicted by MDM"/>
<proteinClass source="MEMSAT3" id="Me" parent_id="" name="MEMSAT3 predicted membrane proteins"/>
</proteinClasses>
<proteinEvidence evidence="Evidence at protein level">
<evidence source="HPA" evidence="Evidence at transcript level"/>
<evidence source="MS" evidence="Not available"/>
<evidence source="UniProt" evidence="Evidence at protein level"/>
</proteinEvidence>
</entry>
답변1
사용행복하다(이전 Perl_6)
~$ raku -MXML -e 'my $xml = open-xml($*ARGFILES.Str); \
.say for $xml.getElementsByTagName("entry").grep(/ TSPAN6 | TNMD /).pairs;' file.xml
#OR
~$ raku -MXML -e 'my @xml = open-xml($*ARGFILES.Str).getElementsByTagName("entry"); \
my @names = <TSPAN6 TNMD>; .say for @xml.grep(/@names/).pairs;' file.xml
실제 XML 파일이 있는 경우 실제 XML 파서를 사용하는 것이 더 좋습니다. 위 코드에서는 XML
명령줄 플래그를 사용하여 Raku 커뮤니티 모듈을 호출합니다 -MXML
(이 방법은 Perl을 사용하여 명령줄에서 모듈을 호출하는 것과 동일합니다). 시간을 들여 현재 XML 스키마에 익숙해진 다음 그에 따라 코딩을 계획하세요.
https://www.Proteinatlas.org/download/ Proteinatlas.xsd
위의 첫 번째 답변은 파일을 $xml
XML 문서로 엽니다. 그런 다음 XML 문서는 entry
명명된(최상위) 요소 로 분류됩니다 .getElementsByTagName();
. 마지막으로 각 요소를 반복하여 grep
원하는 문자열이 포함된 요소를 얻습니다.
위의 두 번째 답변은 이름이 지정된 XML 요소를 검색 entry
하고 파일을 @xml
Raku 배열로 엽니다. 그런 다음 각 요소를 반복하여 grep
원하는 문자열이 포함된 요소를 가져옵니다. 이 요소는 array 에 저장됩니다 @names
.
입력 예(@terdon의 탁월한 답변에서 가져옴):
<?xml version="1.0" encoding="UTF-8"?>
<proteinAtlas xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://v21.proteinatlas.org/download/proteinatlas.xsd" schemaVersion="2.6">
<entry version="21.1" url="http://v21.proteinatlas.org/ENSG00000000003">
<name>TSPAN6</name>
<synonym>T245</synonym>
<synonym>TM4SF6</synonym>
<synonym>TSPAN-6</synonym>
<identifier id="ENSG00000000003" db="Ensembl" version="103.38" assembly="GRCh38.p13" gencodeVersion="37">
<xref id="O43657" db="Uniprot/SWISSPROT"/>
<xref id="7105" db="NCBI GeneID"/>
</identifier>
<proteinClasses>
<proteinClass source="MDM" id="Ma" parent_id="" name="Predicted membrane proteins"/>
<proteinClass source="Ezkurdia et al 2014" id="Eb" parent_id="" name="Protein evidence (Ezkurdia et al 2014)"/>
</proteinClasses>
<proteinEvidence evidence="Evidence at protein level">
<evidence source="HPA" evidence="Evidence at transcript level"/>
<evidence source="MS" evidence="Not available"/>
<evidence source="UniProt" evidence="Evidence at protein level"/>
</proteinEvidence>
</entry>
<entry version="21.1" url="http://v21.proteinatlas.org/ENSG00000000005">
<name>TNMD</name>
<synonym>BRICD4</synonym>
<synonym>ChM1L</synonym>
<synonym>myodulin</synonym>
<synonym>TEM</synonym>
<synonym>tendin</synonym>
<identifier id="ENSG00000000005" db="Ensembl" version="103.38" assembly="GRCh38.p13" gencodeVersion="37">
<xref id="Q9H2S6" db="Uniprot/SWISSPROT"/>
<xref id="64102" db="NCBI GeneID"/>
</identifier>
<proteinClasses>
<proteinClass source="MDM" id="Ma" parent_id="" name="Predicted membrane proteins"/>
<proteinClass source="MDM" id="Md" parent_id="" name="Membrane proteins predicted by MDM"/>
<proteinClass source="MEMSAT3" id="Me" parent_id="" name="MEMSAT3 predicted membrane proteins"/>
</proteinClasses>
<proteinEvidence evidence="Evidence at protein level">
<evidence source="HPA" evidence="Evidence at transcript level"/>
<evidence source="MS" evidence="Not available"/>
<evidence source="UniProt" evidence="Evidence at protein level"/>
</proteinEvidence>
</entry>
</proteinAtlas>
예제 출력:
0 => <entry version="21.1" url="http://v21.proteinatlas.org/ENSG00000000003">
<name>TSPAN6</name>
<synonym>T245</synonym>
<synonym>TM4SF6</synonym>
<synonym>TSPAN-6</synonym>
<identifier version="103.38" gencodeVersion="37" assembly="GRCh38.p13" db="Ensembl" id="ENSG00000000003">
<xref id="O43657" db="Uniprot/SWISSPROT"/>
<xref db="NCBI GeneID" id="7105"/>
</identifier>
<proteinClasses>
<proteinClass id="Ma" source="MDM" parent_id="" name="Predicted membrane proteins"/>
<proteinClass name="Protein evidence (Ezkurdia et al 2014)" parent_id="" id="Eb" source="Ezkurdia et al 2014"/>
</proteinClasses>
<proteinEvidence evidence="Evidence at protein level">
<evidence source="HPA" evidence="Evidence at transcript level"/>
<evidence evidence="Not available" source="MS"/>
<evidence evidence="Evidence at protein level" source="UniProt"/>
</proteinEvidence>
</entry>
1 => <entry version="21.1" url="http://v21.proteinatlas.org/ENSG00000000005">
<name>TNMD</name>
<synonym>BRICD4</synonym>
<synonym>ChM1L</synonym>
<synonym>myodulin</synonym>
<synonym>TEM</synonym>
<synonym>tendin</synonym>
<identifier version="103.38" assembly="GRCh38.p13" db="Ensembl" gencodeVersion="37" id="ENSG00000000005">
<xref id="Q9H2S6" db="Uniprot/SWISSPROT"/>
<xref db="NCBI GeneID" id="64102"/>
</identifier>
<proteinClasses>
<proteinClass name="Predicted membrane proteins" source="MDM" id="Ma" parent_id=""/>
<proteinClass parent_id="" id="Md" name="Membrane proteins predicted by MDM" source="MDM"/>
<proteinClass id="Me" name="MEMSAT3 predicted membrane proteins" parent_id="" source="MEMSAT3"/>
</proteinClasses>
<proteinEvidence evidence="Evidence at protein level">
<evidence evidence="Evidence at transcript level" source="HPA"/>
<evidence evidence="Not available" source="MS"/>
<evidence evidence="Evidence at protein level" source="UniProt"/>
</proteinEvidence>
</entry>
위의 호출은 pairs
출력 요소에 번호를 매깁니다. 마지막으로 @terdon의 의견은 grep
유전자 이름이 가장 안전한 방법이 아닐 수 있음 을 정확하게 지적합니다 . 대신 s를 검색하면 Id
반환 값을 크게 단순화할 수 있습니다(실제로 반환된 제한된 하위 집합이 유용할 경우).
~$ raku -MXML -e 'my $xml=open-xml($*ARGFILES.Str); put $xml.getElementById("ENSG00000000003"|"ENSG00000000005").pairs;' file.xml
반품:
0 <identifier version="103.38" gencodeVersion="37" id="ENSG00000000003" db="Ensembl" assembly="GRCh38.p13">
<xref id="O43657" db="Uniprot/SWISSPROT"/>
<xref id="7105" db="NCBI GeneID"/>
</identifier>
0 <identifier gencodeVersion="37" assembly="GRCh38.p13" version="103.38" db="Ensembl" id="ENSG00000000005">
<xref db="Uniprot/SWISSPROT" id="Q9H2S6"/>
<xref db="NCBI GeneID" id="64102"/>
</identifier>
https://github.com/raku-community-modules/XML
https://rakudo.org/
https://raku.org
답변2
입력이 올바른 형식의 XML 문서라고 가정합니다(예:테든의 답변, 그러나 질문에 표시된 내용은 아님) 특정 및 속성을 사용하여 각 노드의 복사본을 출력하는 데 사용할 수 있습니다 xmlstarlet
.entry
name
proteinClass
source
xmlstarlet select --template \
--copy-of '//entry[name = "TNMD" and proteinClasses/proteinClass/@source = "MEMSAT3"]' \
-nl file
entry
그러면 특정 속성 값을 가진 하위 노드가 name
있는 proteinClasses/proteinClass
특정 속성 값을 가진 모든 노드가 선택됩니다 source
. entry
일치하는 각 노드의 복사본이 후행 개행 문자와 함께 출력됩니다.
답변3
레코드 구분 기호를 사용하여 GNU awk에서 이를 수행할 수 있습니다 </entry[^>]*>
. 예를 들어 다음 파일을 입력으로 사용합니다.
<?xml version="1.0" encoding="UTF-8"?>
<proteinAtlas xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://v21.proteinatlas.org/download/proteinatlas.xsd" schemaVersion="2.6">
<entry version="21.1" url="http://v21.proteinatlas.org/ENSG00000000003">
<name>TSPAN6</name>
<synonym>T245</synonym>
<synonym>TM4SF6</synonym>
<synonym>TSPAN-6</synonym>
<identifier id="ENSG00000000003" db="Ensembl" version="103.38" assembly="GRCh38.p13" gencodeVersion="37">
<xref id="O43657" db="Uniprot/SWISSPROT"/>
<xref id="7105" db="NCBI GeneID"/>
</identifier>
<proteinClasses>
<proteinClass source="MDM" id="Ma" parent_id="" name="Predicted membrane proteins"/>
<proteinClass source="Ezkurdia et al 2014" id="Eb" parent_id="" name="Protein evidence (Ezkurdia et al 2014)"/>
</proteinClasses>
<proteinEvidence evidence="Evidence at protein level">
<evidence source="HPA" evidence="Evidence at transcript level"/>
<evidence source="MS" evidence="Not available"/>
<evidence source="UniProt" evidence="Evidence at protein level"/>
</proteinEvidence>
</entry>
<entry version="21.1" url="http://v21.proteinatlas.org/ENSG00000000005">
<name>TNMD</name>
<synonym>BRICD4</synonym>
<synonym>ChM1L</synonym>
<synonym>myodulin</synonym>
<synonym>TEM</synonym>
<synonym>tendin</synonym>
<identifier id="ENSG00000000005" db="Ensembl" version="103.38" assembly="GRCh38.p13" gencodeVersion="37">
<xref id="Q9H2S6" db="Uniprot/SWISSPROT"/>
<xref id="64102" db="NCBI GeneID"/>
</identifier>
<proteinClasses>
<proteinClass source="MDM" id="Ma" parent_id="" name="Predicted membrane proteins"/>
<proteinClass source="MDM" id="Md" parent_id="" name="Membrane proteins predicted by MDM"/>
<proteinClass source="MEMSAT3" id="Me" parent_id="" name="MEMSAT3 predicted membrane proteins"/>
</proteinClasses>
<proteinEvidence evidence="Evidence at protein level">
<evidence source="HPA" evidence="Evidence at transcript level"/>
<evidence source="MS" evidence="Not available"/>
<evidence source="UniProt" evidence="Evidence at protein level"/>
</proteinEvidence>
</entry>
</proteinAtlas>
다음을 통해 데이터를 얻을 수 있습니다 TNMD
.
$ gawk 'BEGIN{ RS="</entry[^>]*>" } /TNMD/' a
<entry version="21.1" url="http://v21.proteinatlas.org/ENSG00000000005">
<name>TNMD</name>
<synonym>BRICD4</synonym>
<synonym>ChM1L</synonym>
<synonym>myodulin</synonym>
<synonym>TEM</synonym>
<synonym>tendin</synonym>
<identifier id="ENSG00000000005" db="Ensembl" version="103.38" assembly="GRCh38.p13" gencodeVersion="37">
<xref id="Q9H2S6" db="Uniprot/SWISSPROT"/>
<xref id="64102" db="NCBI GeneID"/>
</identifier>
<proteinClasses>
<proteinClass source="MDM" id="Ma" parent_id="" name="Predicted membrane proteins"/>
<proteinClass source="MDM" id="Md" parent_id="" name="Membrane proteins predicted by MDM"/>
<proteinClass source="MEMSAT3" id="Me" parent_id="" name="MEMSAT3 predicted membrane proteins"/>
</proteinClasses>
<proteinEvidence evidence="Evidence at protein level">
<evidence source="HPA" evidence="Evidence at transcript level"/>
<evidence source="MS" evidence="Not available"/>
<evidence source="UniProt" evidence="Evidence at protein level"/>
</proteinEvidence>
이는 "일치하는 경우 이 줄을 인쇄합니다 TNMD
"를 의미합니다. 물론, 라인이 이와 같다면 인쇄될 것이고, 87% identity to TNMD
올바른 파서를 사용하지 않았기 때문에 다양한 극단적인 경우에 분명히 깨질 것입니다.
적절한 파서를 사용하면 문자열이 있어야 할 위치를 정확하게 지정할 수 있습니다.