场景:json数据常以驼峰命名,需要转下划线命名,以对应Python或数据库字段名
命名方式 | 说明 | 特点 | 适用领域 | 示例 |
---|---|---|---|---|
下划线命名 | 单词间用下划线分隔 | 清晰 | Python、MySQL、Oracle | teacher_name |
驼峰命名 | 第一个字母小写,后面其他单词首字母大写 | 短 | json、前端开发、Java、ElasticeSearch | teacherName |
import re
def sub(name):
"""驼峰命名 -> 下划线命名"""
return re.sub('(?<!^)[A-Z]', lambda x: '_'+x.group(), name).lower()
def camel2underline(x):
"""驼峰命名 -> 下划线命名"""
return x[0].lower()+''.join('_'+x[i]if x[i].isupper()else x[i] for i in range(1, len(x))).lower()
for i in ['creditCode', 'price', 'CityId']:
print(i, '->', sub(i))
# 经过测试,正则表达式版本的速度更快
-
print
-
creditCode -> credit_code
price -> price
CityId -> city_id
def underline2camel(name):
"""下划线命名 -> 驼峰命名"""
return name[0].lower() + ''.join(i.title() for i in name.split('_'))[1:]
好吧,又水了一篇博文,讨厌驼峰命名法😓