两种模块

  1. 使用命令库, 发布后, 在任何一个项目中使用
  2. 在项目中建一个任务, 直接通过import 任务名导入模块
    我觉得项目少的时候用第二个就好了. 因为第一种命令库的方式似乎总是出错, 并且每次更新很麻烦: 关闭当前项目, 进入命令库项目, 改完代码再发布, 在进入原项目使用. 而方式1直接修改对应任务就完事了, 立即生效.

    使用

    官方对于模块描述比较简单, 主要讲了对模块内的函数使用和模块全局代码的使用.
    以下以建立一个叫tools的模块举例, 在main的任务中调用tools

导入模块

import tools

函数调用

比如其中有一个add(a,b)函数, main中调用方式为
Dim result = tools.add(1,2)

全局代码调用

main中全局代码调用方式:
tools()

官方没讲的, 全局变量和全局代码的返回值

如果在tools模块中定义了一个全局变量Dim g = 1, 这个全局变量会有如下特点:
在main引入了tools并运行了全局代码tools()后, 可以被tools中其他的函数使用, 但不能被main直接调用, 如:

// tools.task
Dim g = 1 
Function getG()
  return g
End Function

// main.task 正确调用方式
import tools
tools()
log.Info(tools.getG()) // 输出1

// main.task 错误调用方式1
import tools
log.Info(tools.getG()) // 输出错误: 名字 g 没有找到. 需要先运行全局代码,才能初始化g

// main.task 错误调用方式2
import tools
tools()
log.Info(tools.g) // 输出错误: 名字 g 没有找到. g已经被初始化但是只能被tools中的函数访问, 类似私有变量

全局代码也可以有返回值, 如

// tools.task
return 10

// main.task
Log.Info(tools()) //打印10

将一个模块当成一个对象来使用

上面的用法暗示了这个tools.task模块可以作为一个对象使用. 其中的全局变量是模块的私有变量, 全局代码是模块的初始化(构造)函数, 模块的函数全部是公有函数. 这个对象不存在公有变量, 需要用类似set/get()公有函数去模拟公有变量. 也没有私有函数. 私有函数可以通过编码规则去模拟, 如前面加下划线_, 外部函数则不要去调用.

很多海外软件下载速度经常只有几个k,这是要用国内镜像下载。从什么莫名其妙的下载站下载担心带毒,可以从华为云下载。

华为云

可以进入其镜像站搜索:
https://mirrors.huaweicloud.com/home
也可以后面直接加软件名

https://mirrors.huaweicloud.com/xxx软件名/
如:
https://mirrors.huaweicloud.com/git-for-windows/
https://mirrors.huaweicloud.com/git-tortoise/
https://mirrors.huaweicloud.com/python/
https://mirrors.huaweicloud.com/nodejs/

阿里云

主要作为库管理器。如python:
pip config set global.index-url https://mirrors.aliyun.com/pypi/simple
nodejs
npm config set registry https://npm.aliyun.com

中国早期的劳动力分配,是按照是否是城镇人口划分的。没有接受教育的农民天生有地,就可以生活。如果经过学习,则可以通过国家分配进入工厂,进而农转非变为市民。根据这篇文章,关于毕业生的分配有如下叙述:

大约在1950年,当时的政务院发出《为有计划地合理地分配全国公私立高等学校今年暑期毕业生工作的通令》,提出对高校毕业生实行有计划的统筹分配;一年之后,再次发布的《关于改革学制的决定》,规定高校毕业生的工作由政府分配。
恢复高考后,国家仍然沿袭了这一规定。1981年,“文革”后的第一批大学生面临毕业之际,国务院批转了原国家计委、国家教委《关于改进1981年普通高等学校毕业生分配工作的报告》,要求对毕业生按照国家统一计划分配:国家教委直属院校毕业生由国家负责面向全国分配;部委主管院校,毕业生由各部委在本系统、本行业内分配;省属院校的毕业生主要由各省市自治区负责面向本地区分配。
建国初期,城镇人口只有一成,到改革开放初期也不到两成。到了去年也就是2023年,城镇人口已经超过65%。这本身导致了城镇就业人口的增加和农村就业人口的减少。如果在经济不景气的时候,意味着城市里分蛋糕的人口会越来越多,人均蛋糕越来越少。而农村人均需要创造的农业产值,却需要越来越高。
而事实上真正的铁饭碗其实只有农民。中国农民靠天(运气)吃饭,但除了给国家交粮,却不存在被压榨,甚至从古代开始自己有地的农民都是如此。所以如果是农民,确实只需要勤劳耕种,就能有收获。而城镇的企业员工除了给国家交税以外,还存在从生存的城市到所在企业的系统性压榨,所以其勤劳程度并不与其收获成正比,因此难以积攒财富。衣食住行成本一直在随着城市人口密度的提升而提升,而贷款买房又透支了员工的未来。而在企业中打工,多数企业往往不愿分享自己的红利给每个员工,反而是制定种种政策来限制员工。这甚至在很多上市企业中也不是个例,比如薪资结构中的工资部分就是城市的最低工资而避免给员工多交保险、加班不给加班工资而提倡员工“奋斗”、在实施双休日多年后依然实施大小周或单休、实施年假制度数年来不给员工批年假、或者仅按城市最低工资标准发放带薪假工资(如果最低工资占比低,相当于多数收入被扣除)、签署竞业协议禁止员工离职后从事本职业……公司通过法律部门规避了自己的各项风险,而员工则不可能改动任何条款,为了工作迫不得已签署的不平等条约式的劳动合同,或者根本不知道合同里面是否给自己埋了坑。在经济上升期,这些矛盾可能还不明显,因为工作岗位是充足的。而在经济不景气甚至不增长的时候,企业都生存困难,就会拿出不平等的合同条款来转嫁自身风险到员工身上。在企业需要人力的时候为企业加班奋斗,在兴冲冲买了房子背了房贷以后被企业一脚踢出大门。再加上AI在这几年快速兴起,可能很快会替代一些岗位,使得就业岗位更加减少。
现在时不时看到一些高学历人士跑美团、跑滴滴、或者自己开小店、摊煎饼、做民宿等等,可能就是一种后果和趋势。

电商有个困扰是发货的时候,对方提供的地址在省市区部分有缺失,自己要查找起来很麻烦。有没有一个方法能直接获取到一个地址的省市区呢?
比较极限的例子就是没有任何省市区,只有一个地名。比如输入深圳北站,返回广东省、深圳市、龙华区。
我猜测地图API应该可以实现。就问了Gemini。回答的答案居然一次性运行成功,没有编码错误。牛!
我用了高德的API,进驻高德开放平台,创建一个应用即可。而且获取省市区的API只需要KEY就行,没有复杂的鉴权过程。属于“地里编码”类型,每日调用限额5000次。

Gemini回答

以下 API 能够根据地址字符串返回省、市、区:

API 使用方法

高德地图开放平台

GET https://restapi.amap.com/v3/geocode/geo?address=深圳北站&key={{高德地图API Key}}

百度地图开放平台

GET https://api.map.baidu.com/geocoding/v3/?address=深圳北站&output=json&ak={{百度地图API Key}}

API 返回数据示例

高德地图开放平台

{
  "count": 1,
  "info": "OK",
  "infocode": "10000",
  "geocodes": [
    {
      "formatted_address": "广东省深圳市龙华区梅林街道龙胜社区万丰路一号",
      "adcode": "440306",
      "country": "中国",
      "province": "广东省",
      "city": "深圳市",
      "district": "龙华区",
      "township": "梅林街道"
    }
  ]
}

百度地图开放平台

{
  "status": "OK",
  "result": {
    "address": "深圳北站东广场",
    "location": {
      "lat": 22.60116700193512,
      "lng": 114.06170188547761
    },
    "precise": 1,
    "confidence": 70,
    "level": "地铁站",
    "formatted_address": "广东省深圳市龙华区梅林街道龙胜社区万丰路一号(近深圳北站东广场)",
    "business": [],
    "poiRegions": [],
    "semg": [],
    "adname": "广东省深圳市龙华区"
  }
}

示例代码

Python 示例(基于高德地图开放平台)

import requests

def get_address_info(address_string):
    url = "https://restapi.amap.com/v3/geocode/geo"
    params = {
        "address": address_string,
        "key": "YOUR_GAODE_API_KEY"  # 替换为你的高德地图 API Key
    }
    response = requests.get(url, params=params)
    data = response.json()
    if data["info"] == "OK":
        return data["geocodes"][0]["province"], data["geocodes"][0]["city"], data["geocodes"][0]["district"]
    else:
        return None

address_info = get_address_info("深圳北站")
print(address_info)  # 输出:('广东省', '深圳市', '龙华区')

不知道为什么没有人这么总结过.

  • 食: 饮食, 能量来源.
  • 泄: 排泄, 有吃有喝有排泄, 吸收有用的排出有毒的.
  • 息: 气息, 呼吸. 但这一点绝大多数时候是无意识进行的, 不需要意识控制.
  • 温: 温度, 维持人体温度.
  • 眠: 睡眠.
  • 色: 性需求.
    呼吸因为自发自主, 空气又是免费的, 不需要成本. 所以如果讨论是否必须要去有意识付出代价获取的话, 通常可以排除. 余下食泄温眠色.
    老祖宗说食色性也, 包括了食和色. 又说衣食住行, 包括了温食眠. 又说吃喝拉撒, 包括了食泄.
    不过, 从重视程度来说, 食肯定排在第一位的, 温也就是衣可以排在第二位, 这两个都是参与社交, 并作为社交的一部分的, 而且食本身作为社交手段, 又最常用作拉进相互关系. 眠排在第三位, 它不参与社交, 而且直到现代电光源发明之前, 睡眠时长都不存在问题. 泄和色讲起来都颇为忌讳, 其中泄排在第四位, 因为虽然忌讳, 但也从未被禁止过, 而色排在最后一位, 因为不但忌讳, 而且在历史上不断地被各种花式禁止.
    这个问题我问了GPT4, 从其回答顺序和爽快程度上, 也可以看出下面的排位.

我: 请总结对人生存所需要的最基本的生理需求, 包括那几点, 每一点分别用一个汉字来概括.

GPT4: 对人生存所需要的最基本的生理需求通常可以概括为以下几点:

  1. - 人体大部分由水构成,维持身体功能必须要有足够的水分。
  2. - 获取足够的营养包括蛋白质、脂肪、碳水化合物、维生素和矿物质。
  3. - 呼吸新鲜空气来供给身体必需的氧气用于细胞的代谢活动。
  4. - 保持适宜的体温, 既不能过热也不能过冷。
  5. - 充足的睡眠对恢复体力和精神都是必要的。
    这些是人类生存最基础的生理需求。

我: 是否还遗漏了其他方面
GPT4: 我的回答中确实遗漏了其他一些基本生理需求。除了水、食、氧、温和睡之外,还应该包括:
6. - 排泄体内积累的废物和毒素,维持身体的正常功能。
7. - 避险本能,即寻求安全,躲避危险和威胁来保护自己不受伤害。
这些基本生理需求综合起来,构成了人类生存必需的条件。

我: 是否还有遗漏
GPT4: 在以上所述的基本生理需求(水、食、氧、温、睡、排)之外,可以再补充一项基本生理需求:
7. - 生物学上的性需求,涉及繁殖和种族延续。
这七项基础构成了人类生存的核心生理需求。

所以GPT4显然也是受到人类文化熏陶, 总是不肯把所有的关键点一次性说出来.

如果页面使用了shadow-root, 在shadow-root节点以下, 无法使用querySelector进行选择. 这也会导致绝大多数的页面爬虫无法爬取数据, 如chrome插件instant data scraper以及uibot的数据抓取功能. 比如微信的后台都是使用shadow-root的. 个人感觉shadow-root是iframe的一种更优雅的替代技术.

e = $('micro-app') // 选择shadowRoot节点, 可以在开发者工具中看到下面标有#shadow-root(open)的
e.shadowRoot.querySelector('your-css-selector') // 此时就可以选择了

以下代码可以运行. 意味着可以使用回调函数

Function f1(x,y)
    return x + y
end Function
Function f2(x,y)
    return x - y 
End Function
Function a(f)
    Log.Info(f(1,2))
End Function
a(f1)
a(f2)

并且函数名除了作为形参,还可以作为普通变量以及对象的值

Dim f = f2
f('from f')

dim o = {
    'f': f1
}
dim o_f = o['f']
o_f('from o_f')

Function f1(s)
    Log.Info('f1')
    Log.Info(s)
End Function

Function f2(s)
    Log.Info('f2')
    Log.Info(s)

End Function

上面的用法,意味着可以创造类似于接口的功能,使用同一接口函数抽象调用,实际实现可以不同。
另外,也可以实现类似于面向对象的开发,在一个object中除了定义变量还可以定义函数。只是在对象中的函数不能直接写在对象里,也不能匿名,需要在外面写好,在对象里赋值。
同样的,对象里的函数也不能通过o['f']()的方式调用,需要先赋值给变量,再通过变量调用。

另外,发现在函数中使用这种方法会报错,似乎和编译有关:

Function a()
  dim f = f1
  f()
End Function

Function f1()
  log.info(f1)
End Function

报错: 后端错误 unexpected symbol near ')'
这种情况只要将dim f放到全局就会正常,不知道为何,如下:

dim f
Function a()
  f = f1
  f()
End Function

Function f1()
  log.info(f1)
End Function

另外,始终没有找到根据字符串常量表示的函数名调用对应函数的方法。

python中有cpca库, 可以匹配省市区并返回. 但这个库有些老, 好多年不更新, 像深圳龙华区这些近几年升级为区的都没有. 所以需要结合正则实现.
python还有另外一个geopy库也可以实现, 但是这个库需要实时通过API读取, 还总是timeout, 所以放弃这个方案.
UiBot本来支持python扩展来解决, 但是不知为何Uibot自带的python对cpca支持有问题, 始终报错, 所以放弃, 改为Uibot调用系统命令读取打印输出的方式曲线救国.
python代码都是GPT4 Turbo写的, 自己做了小修改.
Uibot测试:

PyTools('parse_address', '广东省深圳市龙华区深圳北站')

Uibot函数:

// 由于通过uibot的python调用存在问题(import cpca始终报错), 所以通过命令行调用
// python路径直接写在tools.bat中, 使用系统where python给出的路径, 避免uibot调用错误的python版本. 此时在系统中使用Pip安装的库可以直接在这儿使用
// tools.bat直接调用执行tools.py. 具体函数在tools.py中实现
// 以Json字符串形式返回
Function PyTools(func, params)
    // params支持单字符串的单参数或者数组形式的多参数
    Dim Ret
    If type('params') = 'string'
        Ret = Sys.Command(@res"tools.bat "+func+" "+params)
    else
        Dim cmd = @res"tools.bat "+func
        For Each p In params 
            cmd = cmd + " " + p
        Next
        Ret = Sys.Command(@res"tools.bat "+func+cmd)
    End if 
    return JSON.Parse(Ret)
End Function

系统命令 tools.bat和python脚本tools.py, 放在uibot项目的res目录下. 如果不放心调用哪个版本的python,可以积极在python前面加路径.

@echo off
python.exe D:\folder\to\project\res\tools.py %1 %2 %3 %4 %5 %6 %7 %8 %9
@echo on

tool.py部分. 大多数是gpt4写的

# tools.py

import sys,re,json
import cpca

def parse_address(address):
    a = ""
    a1 = parse_address1(address)
    a2 = parse_address2(address)
    # 策略: 长度相同优选a1方法, 否则选a2
    if len(a2) <= len(a1):
        a = a1
    else:
        a = a2
    # return f"{a[0]}|{a[1]}|{a[2]}"
    return json.dumps(a, ensure_ascii=False)

# 采用cpca获取省市区. 好处: 不写省市区这几个字都能识别. 问题: 可能有数据库过期问题(龙华区无法识别)
def parse_address1(address):
    # 使用 cpca 库解析地址并返回 DataFrame
    df = cpca.transform([address])
    location = df.iloc[0]  # 提取第一行数据,即我们需要的地址解析结果

    # 返回省市区字符串,用 "|" 分隔
    # return f"{location['省']}|{location['市']}|{location['区']}"
    return list(filter(None,[location['省'], location['市'], location['区']]))

# 采用正则表达式获取省市区. 好处: 不需要更新数据库. 问题: 必须有省市区这几个字.
def parse_address2(address):
    # 更新省/直辖市的匹配模式以处理没有“市”字的直辖市情况
    pattern = re.compile(
        r'(?P<province>[^省]+省|[^自治区]+自治区|北京|天津|上海|重庆)?'
        r'(?P<city>[^市]+市|[^自治州]+自治州|[^地区]+地区|[^盟]+盟)?'
        r'(?P<district>[^县]+县|[^区]+区|[^旗]+旗|[^自治县]+自治县|[^林区]+林区|[^特别行政区]+特别行政区)?'
    )
    match = pattern.search(address)
    if not match:
        return "无法提取地址信息"

    province, city, district = match.group('province', 'city', 'district')

    # 北京、天津、上海和重庆作为直辖市,如果匹配到省份但没有匹配到市,将省份的名字赋给城市
    if province in ['北京', '天津', '上海', '重庆'] and not city:
        city = province
        city = city + '市'

    # 如果没有匹配到,则用空字符串代替
    province = province if province else ''
    city = city if city else ''
    district = district if district else ''

    # 以"|"连接非空字符串
    # result = '|'.join(filter(None, [province, city, district]))

    return list(filter(None,[province, city, district]))

def test_parse_address():
    print(parse_address('广东省深圳市龙华区深圳北站'))


if __name__ == "__main__":
    if len(sys.argv) < 3:
        print("Usage: python tools.py parse_address 'Your Address String Here'")
        sys.exit(1)
    if sys.argv[1] == "parse_address":
        input_address = sys.argv[2]
        result = parse_address(input_address)
        print(result)
    elif sys.argv[1] == "test_parse_address":
        test_parse_address()
    else:
        print('["没有正确的函数名"]')

我: 请数据一个bat文件,可以接受一组参数. 参数为ot时, 将使用ssh命令登录到192.168.1.105端口8022上, 参数为om时, 将使用ssh命令登录到192.168.0.31端口8022上

GPT: 以下是一个能够接受参数的批处理文件的示例:


@echo off

REM 检查传入的参数
IF "%1"=="ot" (
REM 执行连接到192.168.1.105:8022的ssh命令
ssh user@192.168.1.105 -p 8022
) ELSE IF "%1"=="om" (
REM 执行连接到192.168.0.31:8022的ssh命令
ssh user@192.168.0.31 -p 8022
) ELSE (
REM 未提供有效参数时显示帮助信息
echo 请提供有效参数(ot 或 om)
)

REM 结束批处理文件
exit /b


> 请注意,上面的示例假设已经安装了ssh客户端,并且可以通过命令ssh来进行远程登录。

实际运行一次性成功

参考: 2024,像极了1929

这篇文章作者至少在一开始提出了2个真实的、不忽悠人的看法:一是绝大多数人成功自以为是实力实际上是运气;二是在运气产生的时候坚决地迈出去。不靠运气而能洞察未来的人不是没有而是很少。
所以这儿虽说是洞察,也只能把握大趋势,具体到适合个人的小方向上,只能提高好运气的概率。
文中2点和我想的也类似。其一是GPT之类的人工智能是新变革的起点,以后会变成日常生活的一部分,从现在开始在日常中应该更多应用AI;其二是中国尤其是深圳有制造业的优势,在全球都是最好的,如果不加利用非常可惜。
文中对AI有个观点,就是需要与各行各业深入结合,变成“蒸汽机”,深刻提高效率以至于创造力。
文中对中国制造业有两个值得注意的观点:制造业不应像美国一样完全外流,在扩展到海外的同时,而应在国内同时保留一份;另一个是世界级的领导者企业应该、也必然更多在中国产生,也就是更多颠覆者,而不仅仅都是跟随者。我倒是认为颠覆者已经渐渐产生,至是不够深入和全面。目前主要是在互联网领域,比如字节的Tiktok是世界首创的短视频平台、腾讯的微信也让马斯克的X模仿。为什么?因为这个领域进入成本低,一个人有一台电脑就搞定了,创新速度也就更快。字节可以说是靠今日头条积累原始资本,靠抖音发财成为全球现象级产品。对于制造业的个人创新,以前门槛是比美国人高很多的。美国人都有个车库,里面钉锤斧钻样样俱全,从小再这样的环境中长大的人,很容易在鼓捣出些创新硬件产品。中国都住在鸽子楼里缺少这样的环境,然而近年B站不少UP主也利用家里环境和1688的便捷采购鼓捣出不少新玩意。再加上很多硬件设计可以通过电脑完成,如果加上AI的助力,是否能形成一波硬件产品创新的浪潮,就像美国发明了电灯泡洗衣机,日本让磁带、Walkman、游戏机走入每个家庭一样。
现在AI的问题有以下几个,在解决以后,会形成很大助力(我相信近几年会很快解决):

  • 缺少大量的人工信息导入和分析能力。比如AI和爬虫结合, 通过爬虫给AI导入大量的信息, 让AI对解决方案中的原料进行快速寻找、匹配,甚至对解决方案进行自动优化
  • 缺少通用的图片分析能力。根据图片分析产品的尺寸、材质、重量、结构、功能等是否适用。
  • 缺乏数学和逻辑推理能力。
  • 缺乏复杂的编程和自我DEBUG验证能力。
  • 缺乏工程设计图、矢量图、3D图的阅读和编辑能力。比如可以自编辑STEP文件、SVG文件、STL文件等。现在的AI能力主要是位图能力。
  • 事实上其他文档的生成能力也还很初级,比如xlsx等。
    这些方面应该会在近几年快速补齐。有的是AI能力已经足够,只是缺少对应的应用,有的还需要AI本身去提升能力。

希望做一个功能, 通过收集表收集的数据在处理完成后删除掉. 哪种删除方式最方便有效

1. 直接删除统计表: 失败

直接删除统计excel表后, 点击在表格中查看按钮, 会显示表格已经删除, 而且新建相同名称的表格也不能恢复

2. sheet重命名: 失败

重命名sheet后, 仍然在重命名后的sheet中添加数据, 并不能新建sheet添加新数据

3. 在搜集表-统计-已填写-三个点, 一个一个点击移除 : 成功50%

确实可以从统计表sheet中移除数据, 那一行会变成「已移除」, 但是这一行依然存在, 新数据不会覆盖这一行

4. 直接删除统计表数据行: 成功100%

删除数据行后, 新的数据会从新的一行开始

5. 删除sheet后重新关联统计表: 失败

删除sheet后, 可以点击统计表右上角三条杠菜单, 选择'关联的内容', 然后选择对应的收集表, 此时会新建一个收集表同名sheet, 如果已有同名sheet则在名称后面加(1), 而且, 此时会把过往删除的所有收集表信息统统恢复出来.

我们对运气缺乏敬畏,我们对能力过于自信。

运气三角

运气-预测-努力
运气是个体主观上无法把握,但客观上在未来呈一定概率影响个体的事件,是未知的未来,简称为运。
预测是对个体对局势的认识,简称为势,可个体主观上可以了解和把握的未来事件。因为预测是主观的,所以未来未必一定发生。
运气和预测合称为运势。运与势的比例并非一成不变,个人的认识越深刻,就能更多减少运的成分而增加对势的把握。但因为个体的认识必然存在的局限性、以及人类当前知识的局限性,不可能完全杜绝运气成分。
努力是个人为了自己的预测的方向所做的付出。没有方向的付出只能称之为勤奋,也叫做碌碌无为。

运气与希望

“希望”是主观上认为存在可能的好运气,但不一定符合客观事实。但只要存在希望,人就会有努力的动力。
买彩票其实主观希望和客观运气相对偏离不大,因为中彩票的概率是相对容易计算的。
但对未来的希望与运气可能存在较大偏差。这往往是由于个体方向感不强,缺乏对局势的认识。个体容易以近一年的经验去理解余生可能发生的事件,从而产生较大偏差。

运气与奋斗

有些90年代从国企去沿海打工创业的,大多有想法、有能力、肯奋斗,然而在20~30年后,由于商海浮沉,多数仍然没有积累很大财富;而在国企中能力平庸、也没有胆量出来打拼的,20~30年后往往成为高管甚至一把手,享有很高的待遇。从财富角度来讲,在我国的优质国企长期做下来,比在外面打拼奋斗似乎积累了更多财富。创业者把握了方向,但创业的好运气并不多;国企人没有把握方向,却沾上了好运。
2000年开始,中国商品房改革后房价快速上涨,那些结婚早迫于丈母娘压力买房的,最后都笑开了花,那些不愿背负房贷、甚至想要用资金创业的,最后越来越买不起。一个是被迫躺赢,一个是主动奋斗到输光。
上面只说了两个结果与奋斗成反比的例子,是因为成正比的例子更多,翻开几乎任何一个成功人士和成功公司所宣扬的个人奋斗史、公司历史,几乎无不再宣示自己的成功都是自己的勤奋奋斗的结果。
因为历史是胜利者书写的,失败者没有书写历史的权利,因为失败者没有书写的资本、也没有书写的信誉。
然而事实是,多数胜利者只是幸运儿而已。一将功成万骨枯才是现实。多数胜利者的“奋斗等于成功”的故事,只是幸存者偏差罢了。
也有极少数的胜利者,通过深刻的认识把握了正确的方向,不但顺势还能造势。马斯克、王传福、查理芒格是其中佼佼者。
商业竞争中,有一种既得利益者对后来创业者的“看不见、看不起、看不懂、跟不上”的情况(应该是马云所说),这就更说明了这种既得利益者的利益来源是某种运气而已。

对运气的认识之路

由于学校和家庭教育的缘故,在走向社会之前,我一直认为获得成就是靠能力。这儿我跳过了“努力”这一步,因为那时我没怎么努力也获得了很好的成绩,幸运地没和其他考试竞争者一起“卷”。还有一个原因是初中时读了郑渊洁的一部童话作品,其中提到了老子的“唯不争天下莫能与之争”,所以也不愿意卷,当然那时候也还没有深刻地理解这句话的意思。走向社会后,正好碰到中国经济的大发展,需要有能力的人,去了很顶级的公司,这时候对能力的迷信达到了顶峰,认为有能力就能做成一切事情。其实,说到底,广义上的努力也是包括能力的,能力只能通过努力训练得来。只不过有些人由于兴趣等使然,可以不使用“强迫自己的那种努力”主动地训练获取能力,即使用了“兴趣”。
直到三十多岁经历过几个创业公司后,对获得成就又有了新的认知。这时候认为要靠胆识。也就是能够认识到事物发展的方向,并且有胆量去部分或者完全投入这个方向,然后获取成功。这时候,就在找这样的经过成就验证的创业领袖,也就是他依靠其胆识获得了一定成就,并且对同伴非常好的人,认为以其被验证的胆识,必然会继续做出新的成就。这时候已经认识到能力不是关键了,有胆识者,自然会招募到有能力之人来帮自己完成。
对运气的认识,是最近几年的事情,人其实已经到了四十岁左右。自己所认为的有胆识的领袖节节败退屡屡受挫,使自己不得不对曾经坚定的信念怀疑起来。加上疫情以来,众多曾经只能仰望的大佬忽然败的败,跑的跑(乐视恒大等不胜枚举),意识到这些大佬曾经的成功并非全是能力,也并非全靠胆识。过去的成功即使在同一个人身上都难以复制,为什么?因为世界上有太多他们都无法预测之事,而他们有很多相信自己可以预测。预测成功了则是胆识过人,失败了则快速被人遗忘。为什么我过去很难意识到这一点?第一,从教育体制到社会舆论到企业自己的宣传,都不可能承认成就里面有很大运气成分,运气无法把握更无法教育,企业也不可能说自己是凭运气做得这么成功(但失败的时候企业却会说运气不好);第二,疫情前的几十年中国经济快速向上发展,好运气的概率非常大,所以相对容易成功,并且容易反复成功。而现在国家增速放缓,好运概率也大大下降了。
有没有全靠胆识不靠或少靠运气的?有,但是这种人极少极少。所以遇到一个成功的人,可以先断定其中大概率有相当运气成分。接下来他能不能继续成功,就是看他以前的成功的运气成分有多少,以后还有没有这么好运了。
进一步的,如果有人承认自己的成功有很大运气成分,那么他真的可以称得上自我认知清晰、诚实、且高尚了。近的有罗翔老师,远的如寒窑赋(即便是伪托吕蒙正)所说:“人道我贵,非我之能也,此乃时也、运也、命也”。

外观和结构3D文件.STEP处理能力: 失败

.step文件是基于文本的,GPT3.5 可以像模像样的生成,但无法读取, 应该是格式有错误。GPT4则直接拒绝了。

SVG文件处理

绘制APP图标的任务GPT3.5和GPT4都可以实现, 相对来说GPT4实现得更好一些, 不过也需要两三轮的调试对话. 另外, 两者对常见图标的理解会更好, 而不常见的抽象图标的理解就不太到位. 不过还是能给出一些提示的.
更复杂的svg文件输出, GPT4会直接拒绝, 而GPT3.5则来着不惧. 如下面这个任务: 请输出svg代码, 用于表示一个在坐标系中的高斯曲线, 曲线中用虚线表明中位数、-1SD、-2SD、+1SD、+2SD的位置。 GPT4表示我不行,而GPT3.5则输出了一段代码,虽然效果比较差。不知道GPT3.5算不算是无知者无畏?😊
不过如果真的是去找SVG格式的图标的话, 还是不如iconfont更快些.

小程序处理

纯JS的撰写无疑是可以胜任的,但是涉及js/wxml/wxss是否可以胜任? 测试对GPT3.5确实是可以的。