python微信小程序开发项目案例,python容器:字符串(1),Python基础教程

del name_list[0]

print(name_list)

2. pop() – 删除指定下标的数据,如果不指定下标,默认删除最后一个数据,

无论是按照下标还是删除最后一个,pop函数都会返回这个被删除的数据

del_name = name_list.pop()

del_name = name_list.pop(1)

print(del_name)

print(name_list)

3. remove(数据)

name_list.remove(‘ROSE’)

print(name_list)

4. clear() – 清空

name_list.clear()

print(name_list)

5.排序(sort, reverse)

在这里插入图片描述

name_list = [‘TOM’, ‘Lily’, ‘ROSE’]

1. 修改指定下标的数据

name_list[0] = ‘aaa’

print(name_list)

2. 逆序 reverse()

list1 = [1, 3, 2, 5, 4, 6]

list1.reverse()

print(list1)

3. sort() 排序:升序(默认) 和 降序

list1.sort()

list1.sort(reverse=False)

list1.sort(reverse=True)

print(list1)

6.复制(copy)

在这里插入图片描述

name_list = [‘TOM’, ‘Lily’, ‘ROSE’]

list1 = name_list.copy()

print(list1)

print(name_list)

八、列表的循环遍历


1.使用for循环

在这里插入图片描述

name_list = [‘TOM’, ‘Lily’, ‘ROSE’]

for i in name_list:

遍历序列中的数据

print(i)

2.使用while循环

在这里插入图片描述

name_list = [‘TOM’, ‘Lily’, ‘ROSE’]

‘’’

  1. 准备表示下标数据

  2. 循环while

条件 i < 3 len()

遍历:依次按顺序访问到序列的每一个数据

i += 1

‘’’

i = 0

while i < len(name_list):

print(name_list[i])

i += 1

九、列表的嵌套


1.列表嵌套

在这里插入图片描述

name_list = [[‘TOM’, ‘Lily’, ‘Rose’], [‘张三’, ‘李四’, ‘王五’], [‘xiaohong’, ‘xiaoming’, ‘xiaolv’]]

print(name_list)

列表嵌套的时候的数据查询

print(name_list[0])

print(name_list[0][1])

2.应用

一个学校,有3个办公室,现在有8位老师等待工位的分配,请编写程序,完成随机的分配

在这里插入图片描述

在这里插入图片描述

需求:8位老师,3个办公室, 将8位老师随机分配到3个办公室

“”"

步骤:

  1. 准备数据

1.1 8位老师 – 列表

1.2 3个办公室 - 列表嵌套

  1. 分配老师到办公室

*** 随机分配

就是把老师的名字写入到办公室列表 – 办公室列表追加老师名字数据

  1. 验证是否分配成功

打印办公室详细信息:每个办公室的人数和对应的老师名字

“”"

import random

1. 准备数据

teachers = [‘A’, ‘B’, ‘C’, ‘D’, ‘E’, ‘F’, ‘G’, ‘H’]

offices = [[], [], []]

2. 分配老师到办公室 – 取到每个老师放到办公室列表 – 遍历老师列表数据

for name in teachers:

列表追加数据 – append(选中) extend insert

xx[0] – 不能指定是具体某个下标 – 随机

num = random.randint(0, 2)

offices[num].append(name)

print(num)

print(offices)

为了更贴合生活,把各个办公室子列表加一个办公室编号 1, 2, 3

i = 1

3. 验证是否分配成功

for office in offices:

打印办公室人数 – 子列表数据的个数 len()

print(f’办公室{i}的人数是{len(office)},老师分别是:')

打印老师的名字

print() – 每个子列表里面的名字个数不一定 – 遍历 – 子列表

for name in office:

print(name)

i += 1

十、元组


在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

t1 = (10, 20, 30)

print(t1)

print(type(t1))

1. 多个数据元组

t1 = (10, 20, 30)

print(type(t1))

2. 单个数据的元组

t2 = (10,)

print(type(t2))

3. 如果单个数据的元组不加逗号

t3 = (10)

print(type(t3)) # int

t4 = (‘aaa’)

print(type(t4)) # str

t5 = (‘aaa’,)

print(type(t5))

t1 = (‘aa’, ‘bb’, ‘cc’, ‘bb’)

1. 下标

print(t1[0])

2. index()

print(t1.index(‘bb’))

print(t1.index(‘bbb’))

3. count()

print(t1.count(‘aa’))

print(t1.count(‘aaa’))

4. len()

print(len(t1))

t1 = (‘aa’, ‘bb’, ‘cc’, ‘bb’)

t1[0] = ‘aaa’

t2 = (‘aa’, ‘bb’, [‘cc’, ‘dd’])

print(t2[2])

print(t2[2][0])

t2[2][0] = ‘TOM’

print(t2)

十一、字典介绍


在这里插入图片描述

在这里插入图片描述

1.生活中的字典

在这里插入图片描述

2.软件开发中的字典

在这里插入图片描述

创建字典

在这里插入图片描述

{} 键值对 各个键值对用逗号隔开

1. 有数据的字典: name的值TOM, age的值是20, gender的值是男

dict1 = {‘name’: ‘TOM’, ‘age’: 20, ‘gender’: ‘男’}

print(dict1)

print(type(dict1))

2. 创建空字典

dict2 = {}

print(type(dict2))

dict3 = dict()

print(type(dict3))

3.根据键访问值

在这里插入图片描述

在这里插入图片描述

十二、字典的常见操作


1.查看元素

在这里插入图片描述

dict1 = {‘name’: ‘TOM’, ‘age’: 20, ‘gender’: ‘男’}

1. [key]

print(dict1[‘name’]) # 返回对应的值(key存在)

print(dict1[‘names’])

2. 函数

2.1 get()

print(dict1.get(‘name’))

print(dict1.get(‘names’)) # 如果key不存在,返回None

print(dict1.get(‘names’, ‘Lily’))

2.2 keys() 查找字典中所有的key,返回可迭代对象

print(dict1.keys())

2.3 values() 查找字典中的所有的value,返回可迭代对象

print(dict1.values())

2.4 items() 查找字典中所有的键值对,返回可迭代对象,里面的数据是元组,元组数据1是字典的key,元组数据2是字典key对应的值

print(dict1.items())

2.修改元素

在这里插入图片描述

dict1 = {‘name’: ‘TOM’, ‘age’: 20, ‘gender’: ‘男’}

dict1[‘name’] = ‘Lily’

print(dict1)

dict1[‘id’] = 110

print(dict1)

3.添加元素

在这里插入图片描述

在这里插入图片描述

dict1 = {‘name’: ‘TOM’, ‘age’: 20, ‘gender’: ‘男’}

字典序列[key] = 值

id的值是110

dict1[‘id’] = 110

print(dict1)

dict1[‘name’] = ‘ROSE’

print(dict1)

4.删除元素

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

dict1 = {‘name’: ‘TOM’, ‘age’: 20, ‘gender’: ‘男’}

del 删除字典或指定的键值对

del(dict1)

print(dict1)

del dict1[‘name’]

del dict1[‘names’] # 报错

print(dict1)

clear()

dict1.clear()

print(dict1)

5.len()

在这里插入图片描述

6.keys

在这里插入图片描述

dict1 = {‘name’: ‘TOM’, ‘age’: 20, ‘gender’: ‘男’}

for key in dict1.keys():

print(key)

7.values

在这里插入图片描述

dict1 = {‘name’: ‘TOM’, ‘age’: 20, ‘gender’: ‘男’}

for value in dict1.values():

print(value)

8.items

在这里插入图片描述

dict1 = {‘name’: ‘TOM’, ‘age’: 20, ‘gender’: ‘男’}

for item in dict1.items():

print(item)

dict1 = {‘name’: ‘TOM’, ‘age’: 20, ‘gender’: ‘男’}

xx.items(): 返回可迭代对象,内部是元组,元组有2个数据

元组数据1是字典的key,元组数据2是字典的value

for key, value in dict1.items():

print(key)

print(value)

目标: key=value

print(f’{key}={value}')

9.has_key (Python3 已取消)

在这里插入图片描述

十三、字典的遍历


在这里插入图片描述

1.字符串遍历

在这里插入图片描述

2.列表遍历

在这里插入图片描述

3.元组遍历

在这里插入图片描述

4.字典遍历

遍历字典的key(键)

在这里插入图片描述

遍历字典的value(值)

在这里插入图片描述

遍历字典的项(元素)

在这里插入图片描述

遍历字典的key-value(键值对)

在这里插入图片描述

5. 想一想,如何实现带下标索引的遍历

在这里插入图片描述

6.字典的扩展

有序字典:OrderDcit

在这里插入图片描述

在这里插入图片描述

十四、集合


1.创建集合

在这里插入图片描述

在这里插入图片描述

1. 创建有数据的集合

s1 = {10, 20, 30, 40, 50}

print(s1)

s2 = {10, 30, 20, 40, 30, 20}

print(s2)

s3 = set(‘abcdefg’)

print(s3)

2. 创建空集合: set()

s4 = set()

print(s4)

print(type(s4))

s5 = {}

print(type(s5))

2.集合常见操作方法

增加数据

在这里插入图片描述

s1 = {10, 20}

1. 集合是可变类型

add()

s1.add(100)

print(s1)

集合有去重功能,如果追加的数据是集合已有数据,则什么事情都不做

s1.add(100)

print(s1)

s1.add([10, 20, 30]) # 报错

print(s1)

update(): 增加的数据是序列

s1.update([10, 20, 30, 40, 50])

print(s1)

s1.update(100) # 报错

print(s1)

删除数据

在这里插入图片描述

在这里插入图片描述

s1 = {10, 20, 30, 40, 50}

remove(): 删除指定数据,如果数据不存在报错

s1.remove(10)

print(s1)

s1.remove(10) # 报错

print(s1)

discard():删除指定数据,如果数据不存在不报错

s1.discard(10)

print(s1)

s1.discard(10)

print(s1)

pop(): 随机删除某个数据,并返回这个数据

del_num = s1.pop()

print(del_num)

print(s1)

查找数据

在这里插入图片描述

s1 = {10, 20, 30, 40, 50}

in 或not in 判断数据10是否存在

print(10 in s1)

print(10 not in s1)

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Python工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Python开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img



既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Python开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注Python)
img

5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3hpYW90YWkxMjM0,size_16,color_FFFFFF,t_70#pic_center)

s1 = {10, 20, 30, 40, 50}

in 或not in 判断数据10是否存在

print(10 in s1)

print(10 not in s1)

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Python工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Python开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
[外链图片转存中…(img-7qnEAf41-1712433690639)]
[外链图片转存中…(img-8S74C9bH-1712433690640)]



既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Python开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注Python)
[外链图片转存中…(img-jywXXCRm-1712433690640)]

微信小程序支付需要先在微信公众平台上完成开发者账号注册、小程序创建、商户账号注册等一系列步骤,才能获得相关信息(如appid、mch_id、key等)来进行支付接口开发。以下是简要的支付接口开发流程: 1. 获取预支付交易会话标识prepay_id,生成支付签名(注意,签名需要按照微信支付的规则进行签名,详情请参考微信支付官方文档),并将prepay_id、签名、时间戳等信息返回给小程序前端。 2. 小程序前端在收到支付相关信息后,可以调用微信支付API发起支付请求。 3. 微信支付后台会处理支付请求,并给小程序前端返回支付结果。 以下是一个使用Python进行微信小程序支付的示例代码: ```python import requests import hashlib import time import xml.etree.ElementTree as ET # 小程序appid和商户号 app_id = 'your_app_id' mch_id = 'your_mch_id' # 支付相关的接口地址 unified_order_url = 'https://api.mch.weixin.qq.com/pay/unifiedorder' order_query_url = 'https://api.mch.weixin.qq.com/pay/orderquery' # 商户key key = 'your_key' # 生成签名 def generate_sign(params): sign = '' stringA = '&'.join(["{0}={1}".format(k, params.get(k)) for k in sorted(params)]) stringSignTemp = '{0}&key={1}'.format(stringA, key) sign = hashlib.md5(stringSignTemp.encode('utf-8')).hexdigest().upper() return sign # 生成随机字符串 def generate_nonce_str(): return hashlib.md5(str(time.time()).encode('utf-8')).hexdigest() # 获取预支付交易会话标识prepay_id def get_prepay_id(openid, total_fee): params = { 'appid': app_id, 'mch_id': mch_id, 'nonce_str': generate_nonce_str(), 'body': 'test', # 商品描述 'out_trade_no': 'your_order_id', # 商户订单号 'total_fee': total_fee, # 订单总金额,单位为分 'spbill_create_ip': 'your_client_ip', # 客户端ip 'notify_url': 'your_notify_url', # 支付结果回调地址 'trade_type': 'JSAPI', 'openid': openid } # 生成签名 sign = generate_sign(params) params['sign'] = sign # 将参数转换为xml格式 xml_data = ET.Element('xml') for k, v in params.items(): child = ET.SubElement(xml_data, k) child.text = str(v) xml_str = ET.tostring(xml_data, encoding='utf-8') # 发送请求 response = requests.post(unified_order_url, data=xml_str) # 解析返回的xml数据 result = {} for child in ET.fromstring(response.text): result[child.tag] = child.text prepay_id = result.get('prepay_id') return prepay_id # 查询订单状态 def query_order(out_trade_no): params = { 'appid': app_id, 'mch_id': mch_id, 'out_trade_no': out_trade_no, 'nonce_str': generate_nonce_str() } # 生成签名 sign = generate_sign(params) params['sign'] = sign # 将参数转换为xml格式 xml_data = ET.Element('xml') for k, v in params.items(): child = ET.SubElement(xml_data, k) child.text = str(v) xml_str = ET.tostring(xml_data, encoding='utf-8') # 发送请求 response = requests.post(order_query_url, data=xml_str) # 解析返回的xml数据 result = {} for child in ET.fromstring(response.text): result[child.tag] = child.text return result # 示例 openid = 'your_openid' total_fee = 1 prepay_id = get_prepay_id(openid, total_fee) print('prepay_id:', prepay_id) out_trade_no = 'your_order_id' order_result = query_order(out_trade_no) print('order_result:', order_result) ``` 注意,以上代码中的 `openid` 是用户的openid,`total_fee` 是订单总金额,`out_trade_no` 是商户订单号。在实际开发中,你需要将代码中的 `your_app_id`、`your_mch_id`、`your_key`、`your_order_id`、`your_client_ip`、`your_notify_url` 和 `your_openid` 等参数替换为你自己的参数。同时,你还需要在微信公众平台上设置支付回调地址,并根据实际情况修改代码中的 `unified_order_url` 和 `order_query_url` 等支付相关接口的地址。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值