免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2649 | 回复: 3
打印 上一主题 下一主题

[文本处理] 文本求助-无线基站配置文件更新 [复制链接]

论坛徽章:
18
辰龙
日期:2014-05-21 21:01:4115-16赛季CBA联赛之深圳
日期:2016-12-23 13:51:3815-16赛季CBA联赛之北控
日期:2016-11-28 18:26:3815-16赛季CBA联赛之佛山
日期:2016-11-03 11:18:5815-16赛季CBA联赛之辽宁
日期:2016-07-10 16:09:4115-16赛季CBA联赛之江苏
日期:2016-02-20 23:09:202015亚冠之塔什干棉农
日期:2015-08-17 19:49:492015年亚洲杯之日本
日期:2015-04-30 01:24:342015年亚洲杯之约旦
日期:2015-04-01 00:37:182015年亚洲杯之沙特阿拉伯
日期:2015-03-02 15:55:40处女座
日期:2014-05-25 10:34:0020周年集字徽章-年
日期:2023-04-23 11:17:52
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-02-19 12:59 |只看该作者 |倒序浏览
30可用积分
本帖最后由 bikkuri 于 2015-02-19 17:27 编辑

大家新年好!
我有一个问题向大家请教。

工作中需要管理一批无线基站,对于每个无线基站都需要通过一个xml文件进行配置。
以下是一个配置文件的样本。
文件1:/opt/7420enb/config/enbprofile.xml
  1. <?xml version="1.0"?>
  2. <ENBProfile xmlns="https://www.huawei.com/LTE/ENB/profile/v1">
  3.         <name>enb24042@shanghai</name>
  4.         <IDConfig>
  5.                 <ID>
  6.                         <hex>656e623234303432</hex>
  7.                         <name>enb24042</name>
  8.                 </ID>
  9.         </IDConfig>
  10.         <Location>shanghai</Location>
  11.         <ACL>
  12.                 <security>
  13.                         <Account>
  14.                                 <User>enbadmin</User>
  15.                                 <Password>24042Enb!</Password>
  16.                         </Account>
  17.                         <AuthorizedIP>135.240.146.162</AuthorizedIP>
  18.                 </security>
  19.         </ACL>
  20. </ENBProfile>
复制代码
然后下面是要管理的无线基站的列表:
文件2:/home/enb/enb.lst
  1. 64648 enb43535@shanghai enbadmin 43535Admin# 135.240.144.53
  2. 64649 enb24042@shanghai enbadmin 24042Enb! 135.240.146.162
  3. 64650 enb74324@beijing enbadmin Mc10vin!! 135.254.61.160
  4. 64651 enb52526@beijing enbadmin Mc10vin!! 135.254.62.160
复制代码
希望写一个脚本select_enb.sh或者函数select_enb(),实现当执行select_enb 64650时,就自动从无线基站列表中找到对应的第3行,然后用对应的值来替换xml中的值。
要替换的值包括:
        <name>enb24042@shanghai</name>
                        <hex>656e623234303432</hex>
                        <name>enb24042</name>
        <Location>shanghai</Location>
                                <User>enbadmin</User>
                                <Password>24042Enb!</Password>
                        <AuthorizedIP>135.240.146.162</AuthorizedIP>
其中hex对应的内容为第二个name的字符串对应的十六进制数字串。

谢谢大家!

最佳答案

查看完整内容

回复 1# bikkuri There is the sample code for your referenceNote: you have to modify and add more code for warnings ...$ cat /tmp/enb/enbbase.xml ${ENB_NAME} ${ENB_HEX} ${ENB_BASE} ${ENB_LOC} ${ENB_USER} ...

论坛徽章:
145
技术图书徽章
日期:2013-10-01 15:32:13戌狗
日期:2013-10-25 13:31:35金牛座
日期:2013-11-04 16:22:07子鼠
日期:2013-11-18 18:48:57白羊座
日期:2013-11-29 10:09:11狮子座
日期:2013-12-12 09:57:42白羊座
日期:2013-12-24 16:24:46辰龙
日期:2014-01-08 15:26:12技术图书徽章
日期:2014-01-17 13:24:40巳蛇
日期:2014-02-18 14:32:59未羊
日期:2014-02-20 14:12:13白羊座
日期:2014-02-26 12:06:59
2 [报告]
发表于 2015-02-19 12:59 |只看该作者
回复 1# bikkuri

There is the sample code for your reference
Note: you have to modify and add more code for warnings ...

$ cat /tmp/enb/enbbase.xml
<?xml version="1.0"?>
<ENBProfile xmlns="https://www.huawei.com/LTE/ENB/profile/v1">
        <name>${ENB_NAME}</name>
        <IDConfig>
                <ID>
                        <hex>${ENB_HEX}</hex>
                        <name>${ENB_BASE}</name>
                </ID>
        </IDConfig>
        <Location>${ENB_LOC}</Location>
        <ACL>
                <security>
                        <Account>
                                <User>${ENB_USER}</User>
                                <Password>${ENB_PASS}</Password>
                        </Account>
                        <AuthorizedIP>${ENB_IP}</AuthorizedIP>
                </security>
        </ACL>
</ENBProfile>

$ cat /tmp/enb/enb.lst
64648 enb43535@shanghai enbadmin 43535Admin# 135.240.144.53
64649 enb24042@shanghai enbadmin 24042Enb! 135.240.146.162
64650 enb74324@beijing enbadmin Mc10vin!! 135.254.61.160
64651 enb52526@beijing enbadmin Mc10vin!! 135.254.62.160

$ bash select_enb.sh 64650
<?xml version="1.0"?>
<ENBProfile xmlns="https://www.huawei.com/LTE/ENB/profile/v1">
        <name>enb74324@beijing</name>
        <IDConfig>
                <ID>
                        <hex>656e623734333234</hex>
                        <name>enb74324</name>
                </ID>
        </IDConfig>
        <Location>beijing</Location>
        <ACL>
                <security>
                        <Account>
                                <User>enbadmin</User>
                                <Password>Mc10vin!!</Password>
                        </Account>
                        <AuthorizedIP>135.254.61.160</AuthorizedIP>
                </security>
        </ACL>
</ENBProfile>


$ cat select_enb.sh
select_enb(){
  ENB_PATH="/tmp/enb/"
  ENB_FILE="$ENB_PATH/enbbase.xml"
  ENB_LIST="$ENB_PATH/enb.lst"
  awk -vt="$1" '
    BEGIN{
      split("x NAME USER PASS IP",a," ")
      for(n=33;n<127;n++)
        x[sprintf("%c",n)]=sprintf("%02x",n)
    }
    FNR==NR{
      if(t==$1){
        c=NF
        for(n=2;n<=c;n++){
          b[a[n]] = $n
        }
      }
      next
    }
    {
      s=s$0"\n"
    }
    END{
      split(b["NAME"],N,"@")
      b["BASE"]=N[1]
      b["LOC"]=N[2]
      len=length(N[1])
      for(n=1;n<=len;n++)
        b["HEX"]=b["HEX"]x[substr(N[1],n,1)]
      for(n in b)
        v=v"ENB_"n"="b[n]";"
      gsub("\"","\\\"",s)
      cmd=v"\necho -n \""s"\""
      #print cmd
      system(cmd)
    }
  ' $ENB_LIST $ENB_FILE


}
select_enb $1   

论坛徽章:
18
辰龙
日期:2014-05-21 21:01:4115-16赛季CBA联赛之深圳
日期:2016-12-23 13:51:3815-16赛季CBA联赛之北控
日期:2016-11-28 18:26:3815-16赛季CBA联赛之佛山
日期:2016-11-03 11:18:5815-16赛季CBA联赛之辽宁
日期:2016-07-10 16:09:4115-16赛季CBA联赛之江苏
日期:2016-02-20 23:09:202015亚冠之塔什干棉农
日期:2015-08-17 19:49:492015年亚洲杯之日本
日期:2015-04-30 01:24:342015年亚洲杯之约旦
日期:2015-04-01 00:37:182015年亚洲杯之沙特阿拉伯
日期:2015-03-02 15:55:40处女座
日期:2014-05-25 10:34:0020周年集字徽章-年
日期:2023-04-23 11:17:52
3 [报告]
发表于 2015-02-21 01:43 |只看该作者
本帖最后由 bikkuri 于 2015-02-21 01:44 编辑

非常感谢!
awk的数组我一直不太会用,您的代码我能看懂,但是自己写就写不出来。
我之前一直在尝试用sed -i 来做替换,没想到可以用awk的数组来处理。
太感谢了。

jason680 发表于 2015-02-19 12:59
回复 1# bikkuri

There is the sample code for your reference
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP