Python库——Faker——生成伪造数据的第三方库
最近做一个项目时需要随机生成人的名字,百度之后,我是这样写的:
def random_first_name(): """百家姓中选择一个""" name = ['赵', '钱', '孙', '李', '周', '吴', '郑', '王', '冯', '陈', '褚', '卫', '蒋', '沈', '韩', '杨', '朱', '秦', '尤', '许', '何', '吕', '施', '张', '孔', '曹', '严', '华', '金', '魏', '陶', '姜', '戚', '谢', '邹', '喻', '柏', '水', '窦', '章', '云', '苏', '潘', '葛', '奚', '范', '彭', '郎', '鲁', '韦', '昌', '马', '苗', '凤', '花', '方', '俞', '任', '袁', '柳'] return random.choice(name) def random_last_name(): """生成随机汉语""" head = random.randint(0xb0, 0xf7) body = random.randint(0xa1, 0xf9) # 在head区号为55的那一块最后5个汉字是乱码,为了方便缩减下范围 val = f'{head:x}{body:x}' str_ = bytes.fromhex(val).decode('gb2312') return str_ name = random_first_name() + random_last_name()
在编写程序过程中,我们常常需要用到很多数据来进行测试。如果要是手动制造数据的话,肯定要花费大把精力,这不合理。此时我们应该使用Faker这个Python库,用它来生成各种各样的伪数据。
Faker——生成伪造数据的第三方库
项目地址:faker
安装:
pip install Faker
那么Faker能生成哪些假数据呢?
from faker import Faker fake = Faker(locale='zh_CN') # 初始化
基本用法
from faker import Faker # 从faker模块导入Faker这个类。 fake = Faker() # 实例化,保存到变量fake中。 fake.name() # 调用name()方法随机生成一个名字。 # Donna Kelly fake.address() # 调用address()方法随机生成地址信息。 # 519 Donna River # Port Natalie, SD 87384
如果要生成中文的随机数据,我们可以在实例化时给locale参数传入‘zh_CN’这个值:
from faker import Faker fake = Faker(locale='zh_CN') fake.name() # 庞超 fake.address() # 河北省辛集县合川张街p座 489476
如果要生成中文繁体字,则可以传入中国台湾这个地区的值'zh_TW'(当然地址显示的是台湾的):
from faker import Faker fake = Faker(locale='zh_TW') fake.name() # 羅婉婷 fake.address() # 16934 大里縣水源巷35號之0
如果要生成其他语种或地区的数据,我们可以传入相应的地区值:
ar_EG - Arabic (Egypt) ar_PS - Arabic (Palestine) ar_SA - Arabic (Saudi Arabia) bg_BG - Bulgarian bs_BA - Bosnian cs_CZ - Czech de_DE - German dk_DK - Danish el_GR - Greek en_AU - English (Australia) en_CA - English (Canada) en_GB - English (Great Britain) en_NZ - English (New Zealand) en_US - English (United States) es_ES - Spanish (Spain) es_MX - Spanish (Mexico) et_EE - Estonian fa_IR - Persian (Iran) fi_FI - Finnish fr_FR - French hi_IN - Hindi hr_HR - Croatian hu_HU - Hungarian hy_AM - Armenian it_IT - Italian ja_JP - Japanese ka_GE - Georgian (Georgia) ko_KR - Korean lt_LT - Lithuanian lv_LV - Latvian ne_NP - Nepali nl_NL - Dutch (Netherlands) no_NO - Norwegian pl_PL - Polish pt_BR - Portuguese (Brazil) pt_PT - Portuguese (Portugal) ro_RO - Romanian ru_RU - Russian sl_SI - Slovene sv_SE - Swedish tr_TR - Turkish uk_UA - Ukrainian zh_CN - Chinese (China Mainland) zh_TW - Chinese (China Taiwan)
姓名相关
fake.first_name() # 名字 # '强' fake.first_name_female() # 名字(女) # '桂荣' fake.first_name_male() # 名字(男) # '志强' fake.first_romanized_name() # 名字(罗马文) # 'Chao' fake.last_name() # 姓 # '宋' fake.last_name_female() # 姓(女) # '陆' fake.last_name_male() # 姓(男) # '曾' fake.last_romanized_name() # 姓(罗马文) # 'Xie' fake.name() # 姓名 # '王凯' fake.name_female() # 姓名(女) # '戴丽丽' fake.name_male() # 姓名(男) # '刘荣' fake.prefix() # 称谓 # '' fake.prefix_female() # 称谓(女) # '' fake.prefix_male() # 称谓(男) # '' fake.romanized_name() # 称谓(罗马文) # 'Guiying Chang' fake.suffix() # 姓名后缀(中文不适用) # '' fake.suffix_female() # '' fake.suffix_male() # ''
电话相关
fake.msisdn() # 完整手机号码(加了国家和国内区号) # '9067936325890' fake.phone_number() # 手机号 # '18520149907' fake.phonenumber_prefix() # 区号 # 145
Python相关
fake.pybool() # Python布尔值 # False fake.pydecimal(left_digits=None, right_digits=None, positive=False, min_value=None, max_value=None) # Python十进制数 # Decimal('-837022273798.0') fake.pydict(nb_elements=10, variable_nb_elements=True, *value_types) # Python字典 # { '一种': 6381, # '可以': -9242847.69292, # '地址': 9668, # '拥有': 'jVBverSGAJvHsrcZPFDg', # '控制': Decimal('-98521.0'), # '本站': datetime.datetime(1983, 5, 30, 22, 51, 22), # '来源': 'MRTmgbdlwNlqHiIDUVTN', # '标题': 929, # '注册': 'QvYtlygVIopYPasYHCQr', # '解决': -7138575.3, # '问题': 1115.0} fake.pyfloat(left_digits=None, right_digits=None, positive=False, min_value=None, max_value=None) # Python浮点数 # 6.7442382094132 fake.pyint(min_value=0, max_value=9999, step=1) # Python整型值 # 8326 fake.pyiterable(nb_elements=10, variable_nb_elements=True, *value_types) # Python可迭代对象 # {'gang42@gmail.com', Decimal('-638462592926556.0'), 5383, 1608, 185608.962728, datetime.datetime(2013, 8, 7, 10, 44, 51), 'xvqHfWdLyTkaFoguvnqd', datetime.datetime(1999, 9, 10, 4, 41, 29), Decimal('4627589014.65023'), 'http://57.cn/category/', 'UZJwIrsLowvwVGAChwzB', Decimal('68.623476938'), 'mtUbDpTHnQAPVjXzknIM'} fake.pylist(nb_elements=10, variable_nb_elements=True, *value_types) # Python列表 # [ 589, # 'https://www.yangbai.cn/main/', # 'http://fang.cn/faq/', # 'HvtSTwWqDtughQLYibOd', # Decimal('-3541501.934427'), # 2758, # datetime.datetime(2018, 2, 22, 9, 51, 8), # 5375, # 'UVXMfCqJyZwBkfgGhQiH', # 'HfxybvRTPwaFmuhwvKLT', # Decimal('-21565647052012.8'), # 'wEqWsXKTputijSMWhCIb'] fake.pyset(nb_elements=10, variable_nb_elements=True, *value_types) # Python集合 # {7105, 'sidMFYVhXjkNZnHHimJJ', 'yexiuying@kw.cn', 'GPxoyEYixUGAoRCiEmDe', datetime.datetime(2001, 6, 17, 12, 49, 57), 'vOsPAdmmCmkJxeBUpBJP', -75011.0} fake.pystr(min_chars=None, max_chars=20) # Python字符串 # 'NOlWELuogcxSfRjYauSV' fake.pystruct(count=10, *value_types) # Python结构 # ( [ 'SQeHWPNdooccsfbZslee', # 'nDXibfaPXSpmIpxtDUWP', # 'DrZHepzMfNPRrxgcXwvR', # 988.956374402, # 7239, # 4885, # datetime.datetime(1972, 6, 13, 14, 18, 11), # -582284.9732, # datetime.datetime(1997, 8, 23, 9, 19, 6), # 'http://www.hu.cn/homepage.php'], # { '一般': 'oqUQKBhqNylyofEditXs', # '不要': 'qTlztJembuRZHFEzZnGO', # '价格': -2100690667.387, # '国内': datetime.datetime(1989, 9, 3, 11, 27, 11), # '密码': 'aWaufuJAzfgeuhyXAwDL', # '开发': 'aJvNisEMynJcAPhbNAHa', # '方法': 'WVEqHUnnkpUbAnllUqKL', # '汽车': 'bfQlaULiNfjgkrqQUCnL', # '用户': 'WDYNlInLyCcIXMFgyLDS', # '那个': 'qWivpUnOcTwGDhOXihOb'}, # { '个人': { 1: 'http://www.ik.cn/categories/tags/search/homepage/', # 2: [ 'gBSKOBAYYlPwILaWgory', # 'xoeueUWWgbvNHDxKYASD', # 'nkcelmDSpqiQasuKvNZg'], # 3: { 1: 2000, # 2: 'SeDZKUpCxrCLlrDIlPxV', # 3: [Decimal('7833105.737'), Decimal('-7.994')]}}, # '帖子': { 0: 'HXTKojcilYqgYmFUMjuk', # 1: [6887, 3635, 'http://hezhu.com/list/main/terms.html'], # 2: { 0: 'hkong@fujiang.cn', # 1: 4676, # 2: ['JYEFavcRqcsdpnSMwENU', 'vxu@gmail.com']}}, # '应该': { 7: 'EmzzdZrmUpIetxPktXAU', # 8: [ Decimal('4786692875733.0'), # datetime.datetime(2016, 10, 11, 10, 38, 20), # 'ghtelDQAsBeYDaokgbYg'], # 9: { 7: 'yanding@yahoo.com', # 8: 'dtjdazSyZCStWkVYwIvK', # 9: ['TPTzKNGReDCJmrfTkKmd', 'TKQmVfrNRioICuqCrrDQ']}}, # '我的': { 3: 'http://17.cn/home/', # 4: [ 'https://www.guiyingsu.cn/category/', # 'gweRIERFoojbKxRiiliG', # 'dMjUNjDRCSpdrNAlHXRp'], # 5: { 3: 'YeIsIoVHcIgAQWYZkQiR', # 4: 'hGDzyNMVafuDMXSbbhzY', # 5: [977, 'xCFBFdaPHNyFscSCqEWd']}}, # '或者': { 9: 'owgjdYQvTWZIZRewhkev', # 10: ['nHusiXLRunAMvynwjJgu', 6500, 'cQRHfcdFJGUyPDlIocqG'], # 11: { 9: 'sETogfbiwRIqFlrGXeiT', # 10: 'tliang@kong.cn', # 11: [ 'https://chaohao.cn/register.html', # 'fang21@yahoo.com']}}, # '技术': { 4: 8843, # 5: [-5660697068472.0, 7952, -52210308185.53], # 6: { 4: 6477, # 5: 8669, # 6: ['sGueDRKWFAtTExnruySP', 'YZcIHHkbDRLUgeHhblCu']}}, # '深圳': { 5: 2532, # 6: [ Decimal('66661967013036.0'), # 'lei14@yahoo.com', # 'https://www.fangyao.cn/categories/search.html'], # 7: { 5: datetime.datetime(1988, 9, 11, 2, 30, 1), # 6: 50.1, # 7: [ 'https://www.gang.cn/', # 'http://www.liao.cn/posts/app/main.html']}}, # '生产': { 2: 2187, # 3: [ 8629589.339, # 'QvftOABFsahZurjYIPTr', # 'GumqSZMuOSIfrUzjTzKO'], # 4: { 2: 1982, # 3: 'WatxfisQAelRTuwopoOA', # 4: ['xiacheng@00.cn', 'flrVEiuWlEnJjbxCazQG']}}, # '起来': { 6: 'luming@yahoo.com', # 7: [ 'http://www.yu.cn/home.php', # 'vvmhckwxQGnMCafhjXIA', # Decimal('-511928454.48')], # 8: { 6: 'https://www.naguiying.cn/', # 7: 279.928, # 8: [5034, 'shaochao@17.cn']}}, # '那么': { 8: 'PNrBODNdjLnhalWpVMXk', # 9: [ datetime.datetime(1973, 7, 4, 11, 42, 8), # 'iye@gmail.com', # 'iEPyTnfNhNhWWXbkStQC'], # 10: { 8: Decimal('-227034846260.0'), # 9: Decimal('616424892362.0'), # 10: [ 'AjpDMNozhUbedUuOZWdL', # datetime.datetime(1972, 10, 27, 8, 36, 39)]}}}) fake.pytuple(nb_elements=10, variable_nb_elements=True, *value_types) # Python元组 # ( Decimal('989085669.60574'), # 'yang44@hotmail.com', # 794, # datetime.datetime(1989, 12, 11, 4, 10, 40), # 234, # 'TyEwXywfUShjlUVwtMAk', # 'NLUdMSRYoBHmGGPhbwor', # -69.356824324)
身份证相关
fake.ssn(min_age=18, max_age=90) # 身份证 # '410622198603154708'
用户代理相关
fake.android_platform_token() # 安卓 # 'Android 5.0.1' fake.chrome(version_from=13, version_to=63, build_from=800, build_to=899) # Chrome # ('Mozilla/5.0 (Macintosh; U; Intel Mac OS X 10_10_9) AppleWebKit/534.0 (KHTML, ' # 'like Gecko) Chrome/62.0.826.0 Safari/534.0') fake.firefox() # FireFox # ('Mozilla/5.0 (Windows NT 5.1; cs-CZ; rv:1.9.0.20) Gecko/2010-12-02 06:14:30 ' # 'Firefox/3.6.5') fake.internet_explorer() # Ie # 'Mozilla/5.0 (compatible; MSIE 7.0; Windows 95; Trident/3.0)' fake.ios_platform_token() # ios # 'iPhone; CPU iPhone OS 5_1_1 like Mac OS X' fake.linux_platform_token() # Linux # 'X11; Linux i686' fake.linux_processor() # Linux处理器 # 'x86_64' fake.mac_platform_token() # Mac # 'Macintosh; U; PPC Mac OS X 10_11_2' fake.mac_processor() # Mac处理器 # 'Intel' fake.opera() # Opera # 'Opera/8.32.(Windows 98; Win 9x 4.90; mr-IN) Presto/2.9.188 Version/10.00' fake.safari() # Safari # ('Mozilla/5.0 (Windows; U; Windows NT 6.0) AppleWebKit/533.43.6 (KHTML, like ' # 'Gecko) Version/4.0.5 Safari/533.43.6') fake.user_agent() # 随机用户代理 # 'Mozilla/5.0 (compatible; MSIE 9.0; Windows 95; Trident/3.0)' fake.windows_platform_token() # Windows # 'Windows NT 6.2'
地址相关
fake.address() # 地址 # '香港特别行政区大冶县上街钟街k座 664713' fake.building_number() # 楼名 # 'v座' fake.city() # 完整城市名 # '长春县' fake.city_name() # 城市名字(不带市县) # '梧州' fake.city_suffix() # 城市后缀名 # '市' fake.country() # 国家名称 # '厄立特里亚' fake.country_code(representation="alpha-2") # 'BZ' # 国家编号 fake.district() # 地区 # '沙湾' fake.postcode() # 邮编 # '332991' fake.province() # 省 # '河北省' fake.street_address() # 街道地址 # '武汉街D座' fake.street_name() # 街道名称 # '广州路' fake.street_suffix() # 街道后缀名 # '路'
汽车相关
fake.license_plate() # 牌照 # 'ZCO 000'
银行相关
fake.bank_country() # 银行所属国家 # 'GB' fake.bban() # 基本银行账号 # 'TPET9323218579379' fake.iban() # 国际银行代码 # 'GB82IRVM1531009974701'
条形码相关
fake.ean(length=13) # EAN条形码 # '5456457843465' fake.ean13() # EAN13条形码 # '2689789887590' fake.ean8() # EAN8条形码 # '52227936'
颜色相关
fake.color_name() # 颜色名称 # 'Orange' fake.hex_color() # 颜色十六进制值 # '#a5cb7c' fake.rgb_color() # 颜色RGB值 # '15,245,42' fake.rgb_css_color() # CSS颜色值 # 'rgb(15,70,13)' fake.safe_color_name() # 安全色 # 'aqua' fake.safe_hex_color() # 安全色十六进制值 # '#881100'
公司相关
fake.bs() # 商业用词 # 'synthesize strategic vortals' fake.catch_phrase() # 妙句(口号) # 'Robust even-keeled service-desk' fake.company() # 公司名称 # '富罳科技有限公司' fake.company_prefix() # 公司名称前缀 # '商软冠联' fake.company_suffix() # 公司名称后缀 # '网络有限公司'
信用卡相关
fake.credit_card_expire(start="now", end="+10y", date_format="%m/%y") # 过期年月 # '11/20' fake.credit_card_full(card_type=None) # 完整信用卡信息 # 'VISA 16 digit\n秀珍 卢\n4653084445257690 11/19\nCVC: 935\n' fake.credit_card_number(card_type=None) # 信用卡卡号 # '4339481813664365360' fake.credit_card_provider(card_type=None) # 信用卡提供商 # 'VISA 19 digit' fake.credit_card_security_code(card_type=None) # 信用卡安全码 # '597'
时间相关
fake.am_pm() # AM或PM # 'PM' fake.century() # 世纪 # 'XII' fake.date(pattern="%Y-%m-%d", end_datetime=None) # 日期字符串(可设置格式和最大日期) # '1998-05-13' fake.date_between(start_date="-30y", end_date="today") # 日期(可设置限定范围) # datetime.date(2014, 8, 17) fake.date_between_dates(date_start=None, date_end=None) # 同上 # datetime.date(2019, 10, 14) fake.date_object(end_datetime=None) # 日期(可设置最大日期) # datetime.date(1981, 12, 20) fake.date_of_birth(tzinfo=None, minimum_age=0, maximum_age=115) # 出生日期 # datetime.date(1931, 12, 8) fake.date_this_century(before_today=True, after_today=False) # 本世纪日期 # datetime.date(2003, 5, 4) fake.date_this_decade(before_today=True, after_today=False) # 本年代中的日期 # datetime.date(2014, 1, 29) fake.date_this_month(before_today=True, after_today=False) # 本月中的日期 # datetime.date(2019, 10, 10) fake.date_this_year(before_today=True, after_today=False) # 本年中的日期 # datetime.date(2019, 3, 6) fake.date_time(tzinfo=None, end_datetime=None) # 日期和时间 # datetime.datetime(1990, 8, 11, 22, 25) fake.date_time_ad(tzinfo=None, end_datetime=None, start_datetime=None) # 日期和时间(从001年1月1日到现在) # datetime.datetime(244, 12, 17, 9, 59, 56) fake.date_time_between(start_date="-30y", end_date="now", tzinfo=None) # 日期时间(可设置限定范围) # datetime.datetime(1995, 4, 19, 17, 23, 51) fake.date_time_between_dates(datetime_start=None, datetime_end=None, tzinfo=None) # 同上 # datetime.datetime(2019, 10, 14, 14, 15, 36) fake.date_time_this_century(before_now=True, after_now=False, tzinfo=None) # 本世纪中的日期和时间 # datetime.datetime(2009, 8, 26, 18, 27, 9) fake.date_time_this_decade(before_now=True, after_now=False, tzinfo=None) # 本年代中的日期和时间 # datetime.datetime(2019, 2, 24, 22, 18, 44) fake.date_time_this_month(before_now=True, after_now=False, tzinfo=None) # 本月中的日期和时间 # datetime.datetime(2019, 10, 3, 9, 20, 44) fake.date_time_this_year(before_now=True, after_now=False, tzinfo=None) # 本年中的日期和时间 # datetime.datetime(2019, 2, 10, 7, 3, 18) fake.day_of_month() # 几号 # '23' fake.day_of_week() # 星期几 # 'Tuesday' fake.future_date(end_date="+30d", tzinfo=None) # 未来日期 # datetime.date(2019, 10, 28) fake.future_datetime(end_date="+30d", tzinfo=None) # 未来日期和时间 # datetime.datetime(2019, 10, 28, 21, 4, 35) fake.iso8601(tzinfo=None, end_datetime=None) # iso8601格式日期和时间 # '1995-04-10T00:45:01' fake.month() # 第几月 # '07' fake.month_name() # 月份名称 # 'December' fake.past_date(start_date="-30d", tzinfo=None) # 过去日期 # datetime.date(2019, 10, 3) fake.past_datetime(start_date="-30d", tzinfo=None) # 过去日期和时间 # datetime.datetime(2019, 9, 30, 20, 25, 43) fake.time(pattern="%H:%M:%S", end_datetime=None) # 时间(可设置格式和最大日期时间) # '14:26:44' fake.time_delta(end_datetime=None) # 时间间隔 # datetime.timedelta(0) fake.time_object(end_datetime=None) # 时间(可设置最大日期时间) # datetime.time(4, 41, 39) fake.time_series(start_date="-30d", end_date="now", precision=None, distrib=None, tzinfo=None) # <generator object Provider.time_series at 0x7fadf51e0930> fake.timezone() # 时区 # 'Asia/Baku' fake.unix_time(end_datetime=None, start_datetime=None) # UNIX时间戳 # 393980728 fake.year() # 某年 # '2016'
文件相关
fake.file_extension(category=None) # 文件扩展名 # 'avi' fake.file_name(category=None, extension=None) # 文件名 # '专业.pptx' fake.file_path(depth=1, category=None, extension=None) # 文件路径 # '/的话/以上.ods' fake.mime_type(category=None) # MIME类型 # 'application/xop+xml' fake.unix_device(prefix=None) # UNIX设备 # '/dev/xvdq' fake.unix_partition(prefix=None) # UNIX分区 # '/dev/xvdc6'
坐标相关
fake.coordinate(center=None, radius=0.001) # 坐标 # Decimal('147.543284') fake.latitude() # 纬度 # Decimal('66.519139') fake.latlng() # 经纬度 # (Decimal('55.3370965'), Decimal('-15.427896')) fake.local_latlng(country_code="US", coords_only=False) # 返回某个国家某地的经纬度 # ('25.67927', '-80.31727', 'Kendall', 'US', 'America/New_York') fake.location_on_land(coords_only=False) # 返回地球上某个位置的经纬度 # ('42.50729', '1.53414', 'les Escaldes', 'AD', 'Europe/Andorra') fake.longitude() # 经度 # Decimal('70.815233')
网络相关
fake.ascii_company_email(*args, **kwargs) # 企业邮箱(ascii编码) # 'qiuyan@xiulan.cn' fake.ascii_email(*args, **kwargs) # 企业邮箱+免费邮箱(ascii编码) # 'lei59@78.net' fake.ascii_free_email(*args, **kwargs) # 免费邮箱(ascii编码) # 'pcheng@gmail.com' fake.ascii_safe_email(*args, **kwargs) # 安全邮箱(ascii编码) # 'fangyan@example.org' fake.company_email(*args, **kwargs) # 企业邮箱 # 'scao@pingjing.net' fake.domain_name(levels=1) # 域名 # 'dy.cn' fake.domain_word(*args, **kwargs) # 二级域名 # 'gangxiuying' fake.email(*args, **kwargs) # 企业邮箱+免费邮箱 # 'na13@ding.cn' fake.free_email(*args, **kwargs) # 免费邮箱 # 'fang48@hotmail.com' fake.free_email_domain(*args, **kwargs) # 免费邮箱域名 # 'yahoo.com' fake.hostname(*args, **kwargs) # 主机名 # 'lt-70.53.cn' fake.image_url(width=None, height=None) # 图片URL # 'https://placekitten.com/752/243' fake.ipv4(network=False, address_class=None, private=None) # ipv4 # '160.152.149.78' fake.ipv4_network_class() # ipv4网络等级 # 'b' fake.ipv4_private(network=False, address_class=None) # 私有ipv4 # '10.99.124.57' fake.ipv4_public(network=False, address_class=None) # 公共ipv4 # '169.120.29.235' fake.ipv6(network=False) # ipv6 # 'f392:573f:d60f:9aed:2a4c:36d7:fe5b:7034' fake.mac_address() # MAC地址 # '62:67:79:8c:c2:40' fake.safe_email(*args, **kwargs) # 安全邮箱 # 'jing58@example.org' fake.slug(*args, **kwargs) # URL中的slug # '' fake.tld() # 顶级域名 # 'cn' fake.uri() # URI # 'http://yi.com/list/main/explore/register.php' fake.uri_extension() # URI扩展 # '.php' fake.uri_page() # URI页 # 'terms' fake.uri_path(deep=None) # URI路径 # 'blog/tags/blog' fake.url(schemes=None) # URL # 'http://liutao.cn/' fake.user_name(*args, **kwargs) # 用户名 # 'xiulan80'
去期待陌生,去拥抱惊喜。
分类:
Python常用库/包/模块
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!