免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
论坛 程序设计 Shell sh问题
最近访问板块 发新帖
查看: 2933 | 回复: 5
打印 上一主题 下一主题

sh问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-08-29 21:15 |只看该作者 |倒序浏览
执行sh 的时候出现下面这么两行,请问是出了什么错呢?

awk: cmd. line:29: (FILENAME=cbe_subscriber_dyn.unl FNR=1) fatal: attempt to access field -2147483648

脚本如下:

currdate=`date '+%Y%m%d%H%M%S'`
awk -v currdate=${currdate} 'BEGIN{
        OFS="|"
        FS="|"
}{        
             if (FILENAME == "msisdn.list")        
              {                                       
          msisdn[$1]=sprintf("%s,%s,%s",$2,$3,$4)               
         }                                       

        else if (FILENAME == "numservice.unl")
        {  
          if($3 > currdate)
          {
            if($5 in msisdn)
            {
                    subkey[$1]=msisdn[$5]
            }
          }
          print 111
        }
        else if (FILENAME == "cbe_subscriber_dyn.unl")
        {
             if($1 in subkey)
             {
                     split(subkey[$1],timename,",")         #第一个参数为数值名,第二位分离后的参数名,第三位为分割符
                     validate=timename[1]
                     suspenddate=timename[2]
                     disabledate=timename[3]
              printf "update cbe_subscriber_dyn set validdate='%s',suspendenddate='%s',disableenddate='%s' where subscriberkey=%s;\n" $validate $suspenddate $disabledate $1 >> "update_expiredate.sql"
             }       
          
        }
       
}' msisdn.list numservice.unl cbe_subscriber_dyn.unl

论坛徽章:
59
2015七夕节徽章
日期:2015-08-24 11:17:25ChinaUnix专家徽章
日期:2015-07-20 09:19:30每周论坛发贴之星
日期:2015-07-20 09:19:42ChinaUnix元老
日期:2015-07-20 11:04:38荣誉版主
日期:2015-07-20 11:05:19巳蛇
日期:2015-07-20 11:05:26CU十二周年纪念徽章
日期:2015-07-20 11:05:27IT运维版块每日发帖之星
日期:2015-07-20 11:05:34操作系统版块每日发帖之星
日期:2015-07-20 11:05:36程序设计版块每日发帖之星
日期:2015-07-20 11:05:40数据库技术版块每日发帖之星
日期:2015-07-20 11:05:432015年辞旧岁徽章
日期:2015-07-20 11:05:44
2 [报告]
发表于 2011-08-29 22:04 |只看该作者
这个问题应该放到SHELL区。

论坛徽章:
8
摩羯座
日期:2014-11-26 18:59:452015亚冠之浦和红钻
日期:2015-06-23 19:10:532015亚冠之西悉尼流浪者
日期:2015-08-21 08:40:5815-16赛季CBA联赛之山东
日期:2016-01-31 18:25:0515-16赛季CBA联赛之四川
日期:2016-02-16 16:08:30程序设计版块每日发帖之星
日期:2016-06-29 06:20:002017金鸡报晓
日期:2017-01-10 15:19:5615-16赛季CBA联赛之佛山
日期:2017-02-27 20:41:19
3 [报告]
发表于 2011-08-30 08:20 |只看该作者
printf "update cbe_subscriber_dyn set validdate='\'%s\'',suspendenddate='\'%s\'',disableenddate='\'%s\'' where subscriberkey=%s;\n" ,$validate, $suspenddate ,$disabledate, $1

论坛徽章:
15
2015年辞旧岁徽章
日期:2015-03-03 16:54:15双鱼座
日期:2015-01-15 17:29:44午马
日期:2015-01-06 17:06:51子鼠
日期:2014-11-24 10:11:13寅虎
日期:2014-08-18 07:10:55酉鸡
日期:2014-04-02 12:24:51双子座
日期:2014-04-02 12:19:44天秤座
日期:2014-03-17 11:43:36亥猪
日期:2014-03-13 08:13:51未羊
日期:2014-03-11 12:42:03白羊座
日期:2013-11-20 10:15:18CU大牛徽章
日期:2013-04-17 11:48:45
4 [报告]
发表于 2011-08-30 09:07 |只看该作者
呵呵,单引号在awk 的输出问题。

论坛徽章:
3
2015年迎新春徽章
日期:2015-03-04 09:56:11数据库技术版块每日发帖之星
日期:2016-08-03 06:20:00数据库技术版块每日发帖之星
日期:2016-08-04 06:20:00
5 [报告]
发表于 2011-08-30 09:16 |只看该作者
引号的问题,单引号里面不可以就这样再直接包含真正的字符单引号
另外,变量显然都弄错了,我想
$validate $suspenddate $disabledate $1
这些应该是shell下的变量吧?
总之,是shell下的引号使用错误.
单引号内部所包含的都是实际的字符串,是不可能包shell变量的,如果要用,可以这样
'asdasdasd'"$var"'sdferwerwe'
                单双   双单

论坛徽章:
0
6 [报告]
发表于 2011-09-04 11:45 |只看该作者
这位IT淫士应该是华为做数据迁移的.
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP