1

我有一个包含用户身份信息的 XML 文件。我想自动修改和删除用户,到目前为止使用 XmlStarlet 成功删除。现在我不知道如何通过用户名搜索来修改用户信息。任何人都可以帮助我使用如何使用 xmlstarlet 进行修改的命令

    <table name="MANAGED_USER" keys="CONTEXT_ID,USERNAME">
     <row>
     <column name="USERNAME">IAM_User7</column>
     <column name="CONTEXT_ID">PROVCLIENT</column>
     <column name="ALGORITHM">DESEDE</column>
     <column name="PASSWORD">2e02f952e8743b36</column>
     <column name="FAILED_LOGINS">0</column>
     <column name="REALNAME">IAM User 7</column>
     <column name="VALIDFROM">2013-06-03 00:00:00.0</column>
     <column name="VALIDUNTIL">2014-06-01 00:00:00.0</column>
     <column name="USER_TYPE">1</column>
     <column name="LOCKED">0</column>
     <column name="CHANGED_BY">tam</column>
     <column name="ORGANISATION_NAME" is_null="true">null</column>
    </row>
    </table>

提前致谢

4

1 回答 1

2

像这样的东西?(锁定用户名为“IAM_User7”的用户)

xmlstarlet ed -u '/table/row[column[@name = "USERNAME"] = "IAM_User7"]/column[@name = "LOCKED"]' -v 1 table.xml

假设table.xml包含问题中的内容。


不幸的是,添加新用户非常乏味,这只是前 2 个字段:

xmlstarlet ed -s /table -t elem -n row -v '' \
    --var new '$prev' \
    -s '$new' -t elem -n column -v IAM_User8 \
    -s '$prev' -t attr -n name -v USERNAME \
    -s '$new' -t elem -n column -v PROVCLIENT \
    -s '$prev' -t attr -n name -v CONTEXT_ID \
    table.xml

需要 1.4.0 或更高版本(对于--var$prev; 可以使用带有丑陋技巧的早期版本)。

于 2013-06-14T15:44:50.797 回答