普通视图

发现新文章,点击刷新页面。
昨天以前首页

Python枚举类Enum超详细入门与进阶全攻略

作者 烛阴
2025年6月6日 21:44

一、什么是枚举(Enum)?

Enum(枚举),是用于表示一组有名称的常量类型。每个枚举成员都由唯一的名字和值组成,Python从3.4版本开始加入了标准库enum模块。

枚举优点:

  • 可读性强,表达清晰
  • 防止魔法数字、常量重复
  • 程序更安全、更自解释
  • 可与类型提示、IDE轻松集成

二、Enum 最简用法入门

from enum import Enum

class Weekday(Enum):
    MONDAY = 1
    TUESDAY = 2
    WEDNESDAY = 3

print(Weekday.MONDAY)        # Weekday.MONDAY
print(Weekday.MONDAY.value)  # 1
print(Weekday.MONDAY.name)   # 'MONDAY'

无需担心值重复或非法赋值!


三、高级用法:自动赋值、唯一性与自定义属性

1. 自动赋值

from enum import auto, Enum

class Weekday(Enum):
    MONDAY = auto()
    TUESDAY = auto()
    WEDNESDAY = auto()

auto会自动赋值,省去手动编号烦恼!

2. 保证唯一性

from enum import unique,Enum

@unique
class Status(Enum):
    NORMAL = 1
    ERROR = 2
    CANCEL = 3
    PENDING = 1  #duplicate values found in <enum 'Status'>: PENDING -> NORMAL

print(Status.NORMAL)
print(Status.NORMAL.value)
# 如果有重复值会抛出duplicate values

3. 添加方法和属性

你还可以给枚举添加方法或属性,实现更强大功能:

class VIP(Enum):
    BRONZE = 1
    SILVER = 2
    GOLD = 3

    def level(self):
        return {1: '初级', 2: '中级', 3: '高级'}.get(self.value, '未知')

vip = VIP.GOLD
print(vip.level())   # '高级'

4. 枚举类的比较大小

  • 普通Enum里面的排序是无序的,不支持排序
  • IntEnum支持排序,可以比较大小
from enum import Enum, IntEnum

class User(IntEnum): # IntEnum 如果改成Enum,下面的sorted就会发生异常
   a = 98
   b = 30
   c = 12

try:
   print('\n'.join('  ' + s.name for s in sorted(User)))
except TypeError as err:
   print(' Error : {}'.format(err))

四、枚举的多种类型小结

  • Enum:最基础的通用枚举
  • IntEnum:值必须是int,兼容大小比较等整型操作
  • Flag / IntFlag:位运算枚举,适合状态组合或权限位

IntEnum 示例

from enum import IntEnum
class Level(IntEnum):
    LOW = 0
    MED = 1
    HIGH = 2

print(Level.LOW < Level.HIGH)  # True

Flag示例(位操作)

from enum import Flag, auto
class Permission(Flag):
    READ = auto()
    WRITE = auto()
    EXECUTE = auto()

perm = Permission.READ | Permission.WRITE
print(perm)  # Permission.READ|WRITE

五、枚举的遍历与转换

遍历所有成员

for day in Weekday:
    print(day, day.value)
# 输出 Weekday.MONDAY 1 ... 等

由值获取(反差)

day = Weekday(1)    # 获取Weekday.MONDAY

如果你喜欢这篇文章,欢迎点赞、收藏和转发,更多Python干货内容敬请关注!

自动化测试、前后端mock数据量产利器:Chance.js深度教程

作者 烛阴
2025年6月4日 22:59

1. 什么是Chance.js?

  • 超轻量级(压缩后仅十几KB)
  • API极其丰富,支持姓名、年龄、地址、电话、邮箱、数字、布尔、图片、时间、uuid等几十种数据类型
  • 无外部依赖,适用于Node、前端浏览器等环境
  • 自定义性强,可控制数据范围、格式、多语言等

2. 快速安装与引入

Node环境:

npm install chance
const Chance = require('chance');
const chance = new Chance();

前端浏览器(CDN):

<script src="https://cdn.jsdelivr.net/npm/chance@1.1.11/dist/chance.min.js"></script>
<script>
  var chance = new Chance();
</script>

3. 生成常用假数据

基础属性

console.log(chance.name());       // 随机姓名 e.g. 'Bettie Thornton'
console.log(chance.age());        // 随机年龄 e.g. 54
console.log(chance.gender());     // 随机性别 'Male' or 'Female'
console.log(chance.city());       // 随机城市 e.g. 'Cagaeh'
console.log(chance.country());    // 随机国家 e.g. 'DE'
console.log(chance.phone());      // 随机电话号 e.g. (766) 998-5343
console.log(chance.email());      // 随机邮箱 e.g. 'eptof@wahehasa.gm'
console.log(chance.url());        // 随机网址 e.g. http://gu.bv/sur

数值、布尔、数组

chance.integer({ min: 100, max: 999 });  // 生成指定范围整数
chance.floating({ min: 0, max: 1, fixed: 3 }); // 小数三位
chance.bool();         // true或false
chance.pickone(['red', 'blue', 'green']); // 随机挑选
chance.shuffle([1,2,3,4,5]); // 随机打乱数组

唯一标识与特殊格式

chance.guid();      // GUID/UUID
chance.hash();      // 随机哈希
chance.ip();        // 随机IPv4
chance.natural();   // 随机自然数
chance.timestamp(); // 随机时间戳
chance.date({ year: 2024 }); // 指定年份的日期对象

4. 控制数据范围与定制

Chance 几乎所有API都可以定制参数——范围、位数、样式:

chance.name({ middle: true }); // 带中间名
chance.age({ type: 'child' });      // 0-12岁
chance.phone({ country: 'fr' }); // 法国电话
chance.string({ length: 8, pool: '0123456789ABCDEF' }); // 8位十六进制字符串

5. 批量生成mock数据

常见于表格、列表、接口数据填充:

const list = Array.from({ length: 10 }).map(() => ({
  id: chance.guid(),
  name: chance.name(),
  age: chance.age(),
  email: chance.email(),
  city: chance.city()
}));
console.table(list);

6. 测试、数据可视化、前端mock应用场景

  • 前端开发:接口返回数据无须后端,直接mock填充表单/列表
  • 测试用例:各种格式边界、随机性输入
  • 数据可视化:大规模模拟用户、订单、网络数据
  • 安全测试:大量边界、极端字符串、号码覆盖


7. 常见坑和小贴士

  • 随机字符串如需高复杂度可指定字符池
  • 路径、邮箱、手机号可定制格式,避免后续格式错误
  • 生成大量 mock数据时,推荐批量函数或map

结语

Chance.js 用最简单的方式解决“前端造假数据难题”,是你开发、测试、数据展现的最佳拍档。赶快试试看,用它让你的 mock 代码不再拖沓!

本文只是简单的罗列了Chance.js的一些用法,更多用法可以查看官网


如果你喜欢本教程,记得点赞+收藏!关注我获取最新JavaScript开发干货。

❌
❌