python变量不能以数字打头

在编写python函数时,无意中发现一个问题:python中的变量不能以数字打头,以下函数中定义了一个变量3_num_varchar,执行时报错。

函数如下:

def database_feild_varchar_trans(in_feild):
    '''
    transfer the feild if varchar then 3times lang else no transfer
    '''
    feild_split = in_feild.split(' ')
    is_varchar = feild_split[1].find('VARCHAR')
    if is_varchar >= 0 :
       num_varchar = feild_split[1].replace('VARCHAR','').replace('(','').replace(')','')
       print (num_varchar)
       3_num_varchar = num_varchar*3
       feild_split[1] =  feild_split[1].replace(str(num_varchar),str(3_num_varchar))
       return feild_split
    else:
       print ('The feild type is not varchar')
       return feild_split
报错信息如下:

>>> runfile('E:/procedure/python/projects/others/table_test.py', wdir='E:/procedure/python/projects/others')
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "D:\Python33\lib\site-packages\spyderlib\widgets\externalshell\sitecustomize.py", line 699, in runfile
    execfile(filename, namespace)
  File "D:\Python33\lib\site-packages\spyderlib\widgets\externalshell\sitecustomize.py", line 88, in execfile
    exec(compile(open(filename, 'rb').read(), filename, 'exec'), namespace)
  File "E:/procedure/python/projects/others/table_test.py", line 20
    3_num_varchar = int(num_varchar)*3
                ^
SyntaxError: invalid syntax

将变量3_num_varchar改为num_varchar_3,运行成功,程序改为如下:

import os
import sys
str1='aaa varchar(10)'

def database_feild_varchar_trans(in_feild):
    '''
    transfer the feild if varchar then 3times lang else no transfer
    '''
    feild_split = in_feild.split(' ')
    is_varchar = feild_split[1].find('VARCHAR')
    if is_varchar >= 0 :
       num_varchar = feild_split[1].replace('VARCHAR','').replace('(','').replace(')','')
       print (num_varchar)
       num_varchar_3 = num_varchar*3
       feild_split[1] =  feild_split[1].replace(str(num_varchar),str(num_varchar_3))
       return feild_split
    else:
       print ('The feild type is not varchar')
       return feild_split

print (database_feild_varchar_trans(str1))

运行结果:

>>> runfile('E:/procedure/python/projects/others/table_test.py', wdir='E:/procedure/python/projects/others')
The feild type is not varchar
['aaa', 'varchar(10)']

转载于:https://www.cnblogs.com/herozhao/p/5643877.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值