当前位置: 首页 > news >正文

学习python的第十四天之函数——高阶函数和偏函数

学习python的第十四天之函数——高阶函数和偏函数

高阶函数

高阶函数是指那些可以接受一个或多个函数作为参数,或者返回一个函数作为结果的函数。高阶函数是函数式编程范式中的一个重要概念,它们使得代码更加灵活和模块化。

sorted()

sorted()函数用于对一个可迭代对象(如列表、元组、字符串等)中的元素进行排序,并返回一个新的排序后的列表。sorted() 函数不会改变原始的可迭代对象,而是返回一个新的列表。

语法:sorted(iterable, key=None, reverse=False)

  • iterable: 一个可迭代对象,如列表、元组、字符串等,需要对其进行排序。
  • key(可选): 一个函数,接收一个参数并返回一个用于排序的值。这个函数通常用于指定排序的依据,例如按照元素的某个属性或经过某种变换后的值进行排序。如果没有提供 key,则默认使用元素本身的值进行排序。
  • reverse(可选): 一个布尔值,如果为 True,则按照降序排序;如果为 False(默认),则按照升序排序。

工作原理:

sorted() 函数会对 iterable 中的元素进行排序,并返回一个新的排序后的列表。排序的依据是 key 函数返回的值(如果提供了 key),或者元素本身的值(如果没有提供 key)。排序的顺序由 reverse 参数决定。

对列表进行排序

# 对一个列表进行升序排序
numbers = [5, 2, 9, 1, 5, 6]
sorted_numbers = sorted(numbers)print(sorted_numbers)  # 输出: [1, 2, 5, 5, 6, 9]

使用 key 参数

# 对一个包含字符串的列表按照字符串长度进行排序
words = ['apple', 'banana', 'cherry', 'date']
sorted_words_by_length = sorted(words, key=len)print(sorted_words_by_length)  # 输出: ['date', 'apple', 'cherry', 'banana']

‌使用 reverse 参数

# 对一个列表进行降序排序
numbers = [5, 2, 9, 1, 5, 6]
sorted_numbers_desc = sorted(numbers, reverse=True)print(sorted_numbers_desc)  # 输出: [9, 6, 5, 5, 2, 1]

对元组列表按照特定元素排序

# 对一个包含元组的列表按照元组的第二个元素进行排序
students = [('John', 90), ('Jane', 85), ('Dave', 92), ('Eva', 88)]
sorted_students_by_score = sorted(students, key=lambda student: student)print(sorted_students_by_score)  # 输出: [('Jane', 85), ('Eva', 88), ('John', 90), ('Dave', 92)]

对字典按照特定元素排序

# 按照键排序
# 创建一个字典
my_dict = {'banana': 3, 'apple': 4, 'pear': 1, 'orange': 2}# 按照键排序
sorted_keys = sorted(my_dict.keys())# 输出排序后的键
print(sorted_keys)  # 输出: ['apple', 'banana', 'orange', 'pear']# 如果需要排序后的字典,可以使用字典推导式
sorted_dict_by_keys = {k: my_dict[k] for k in sorted_keys}
print(sorted_dict_by_keys)  # 输出: {'apple': 4, 'banana': 3, 'orange': 2, 'pear': 1}# 按照值排序
# 创建一个字典
my_dict = {'banana': 3, 'apple': 4, 'pear': 1, 'orange': 2}# 按照值排序,并获取键-值对组成的列表
sorted_items_by_values = sorted(my_dict.items(), key=lambda item: item)# 输出排序后的键-值对
print(sorted_items_by_values)  # 输出: [('pear', 1), ('orange', 2), ('banana', 3), ('apple', 4)]# 如果需要排序后的字典,可以使用字典推导式
sorted_dict_by_values = {k: v for k, v in sorted_items_by_values}
print(sorted_dict_by_values)  # 输出: {'pear': 1, 'orange': 2, 'banana': 3, 'apple': 4}# 按照键-值对排序(实际上这是按照键排序的另一种形式,因为键-值对中的键是主要的排序依据)
# 创建一个字典
my_dict = {'banana': 3, 'apple': 4, 'pear': 1, 'orange': 2}# 按照键-值对排序(这里实际上是根据键排序)
sorted_items = sorted(my_dict.items())# 输出排序后的键-值对
print(sorted_items)  # 输出: [('apple', 4), ('banana', 3), ('orange', 2), ('pear', 1)]# 注意:这里不需要使用字典推导式来转换回字典,因为 sorted_items 已经是一个键-值对的列表了。
# 如果确实需要字典形式,可以直接使用 dict(sorted_items),但这样做通常没有意义,因为排序后的列表已经足够表达排序结果。

**map()**‌

map()函数接受两个参数:一个函数和一个可迭代对象(如列表)。它会将这个函数应用到可迭代对象的每个元素上,并返回一个迭代器(在Python 3中,需要用list()将其转换为列表)。

语法:map(function, iterable, …)

  • function: 一个函数,接收一个或多个参数,并返回一个值。这个函数可以是已定义的函数,也可以是一个匿名函数(使用 lambda 表达式)。
  • iterable: 一个或多个可迭代对象。如果提供了多个可迭代对象,function 必须能够接受对应数量的参数,并且这些可迭代对象的长度必须相同(或者最短的长度将被用作结束点)。

工作原理:

map() 函数会对提供的每个可迭代对象中的元素按位置依次应用 function,并返回一个包含所有函数结果的迭代器。

# 定义一个函数,将数值加倍
def double(n):return n * 2# 使用 map() 将列表中的每个元素加倍
numbers = [1, 2, 3, 4, 5]
doubled_numbers = map(double, numbers)# 由于 map() 返回的是一个迭代器,我们需要将其转换为列表以查看结果
print(list(doubled_numbers))  # 输出: [2, 4, 6, 8, 10]

或者使用lambda表达式:

# 使用 lambda 表达式和 map() 将列表中的每个元素加倍
numbers = [1, 2, 3, 4, 5]
doubled_numbers = map(lambda n: n * 2, numbers)# 转换为列表以查看结果
print(list(doubled_numbers))  # 输出: [2, 4, 6, 8, 10]

对多个可迭代对象应用函数

# 定义一个函数,接收两个参数并返回它们的和
def add(x, y):return x + y# 使用 map() 对两个列表中的元素逐对相加
list1 = [1, 2, 3]
list2 = [4, 5, 6]
added_numbers = map(add, list1, list2)# 转换为列表以查看结果
print(list(added_numbers))  # 输出: [5, 7, 9]# 注意:如果两个列表长度不同,map() 会以较短的列表为准
list3 = [1, 2]
list4 = [3, 4, 5]
added_numbers_short = map(add, list3, list4)
print(list(added_numbers_short))  # 输出: [4, 6]
注意事项
  • map() 返回的是一个迭代器,而不是一个列表。如果你需要直接查看结果,可以使用 list() 函数将其转换为列表。
  • 在 Python 2 中,map() 返回的是一个列表,而不是迭代器。这是 Python 2 和 Python 3 之间的一个重要区别。
  • 如果提供了多个可迭代对象,它们必须具有相同的长度(或者最短的长度将被用作结束点),否则 map() 会引发 ValueError

**filter()**‌

filter()函数也接受两个参数:一个函数和一个可迭代对象。用于从一个可迭代对象(如列表、元组、字符串等)中筛选出符合特定条件的元素。它会创建一个迭代器,包含可迭代对象中所有通过提供的函数测试的元素。

语法:filter(function, iterable)

  • function: 一个函数,接收一个参数并返回布尔值 TrueFalsefunction 可以是一个已定义的函数,也可以是一个匿名函数(使用 lambda 表达式)。
  • iterable: 一个可迭代对象,如列表、元组、字符串等。

工作原理:

filter() 函数会对 iterable 中的每个元素应用 function,并返回一个包含所有 function 返回 True 的元素的迭代器。

# 定义一个函数,判断一个数是否为偶数
def is_even(n):return n % 2 == 0# 使用 filter() 筛选出列表中的偶数
numbers = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
even_numbers = filter(is_even, numbers)# 由于 filter() 返回的是一个迭代器,我们需要将其转换为列表以查看结果
print(list(even_numbers))  # 输出: [2, 4, 6, 8, 10]

或者使用lambda表达式:

# 使用 lambda 表达式和 filter() 筛选出列表中的偶数
numbers = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
even_numbers = filter(lambda n: n % 2 == 0, numbers)# 转换为列表以查看结果
print(list(even_numbers))  # 输出: [2, 4, 6, 8, 10]

筛选字符串中的特定字符

# 筛选出字符串中所有的字母 'a'
letters = ['a', 'b', 'c', 'a', 'd', 'e', 'a', 'f']
filtered_letters = filter(lambda x: x == 'a', letters)# 转换为列表以查看结果
print(list(filtered_letters))  # 输出: ['a', 'a', 'a']

与其他函数结合使用

# 结合 map() 和 filter() 使用,先对列表中的元素进行平方,然后筛选出平方后的偶数
numbers = [1, 2, 3, 4, 5]
squared_even_numbers = filter(lambda x: x % 2 == 0, map(lambda x: x * x, numbers))# 转换为列表以查看结果
print(list(squared_even_numbers))  # 输出: [4, 16]
注意事项
  • filter() 返回的是一个迭代器,而不是一个列表。如果你需要直接查看结果,可以使用 list() 函数将其转换为列表。
  • 在 Python 2 中,filter() 返回的是一个列表,而不是迭代器。这是 Python 2 和 Python 3 之间的一个重要区别。
  • filter() 函数不会改变原始的可迭代对象,而是返回一个新的迭代器。

**reduce()**‌

reduce()函数在Python 3中被移到了functools模块中。它接受两个参数:一个函数和一个可迭代对象。这个函数必须接受两个参数,并返回一个值。reduce()会将这个函数应用到可迭代对象的第一个和第二个元素上,得到的结果再和第三个元素一起作为参数传递给这个函数,依此类推,直到处理完整个可迭代对象。

语法:

from functools import reduce (需要从 functools 模块导入 reduce() 函数)

reduce(function, iterable[, initializer])

  • function: 一个接收两个参数的函数。这两个参数通常是序列中的元素,但在第一次调用时,如果提供了 initializer,则第一个参数是 initializer,第二个参数是序列的第一个元素。
  • iterable: 一个可迭代对象,如列表、元组等。
  • initializer(可选): 一个初始值,用于在第一次调用 function 时作为第一个参数。如果没有提供 initializer,则默认使用 iterable 中的第一个元素作为初始值,并从第二个元素开始迭代。

工作原理:

reduce() 函数会对 iterable 中的元素从左到右依次应用 function,每次应用都会将当前结果和下一个元素作为参数传递给 function,直到迭代结束。最终,reduce() 返回的是一个单一的值,即最后一次调用 function 的结果。

from functools import reduce# 定义一个函数,接收两个参数并返回它们的和
def add(x, y):return x + y# 使用 reduce() 计算列表的和
numbers = [1, 2, 3, 4, 5]
sum_of_numbers = reduce(add, numbers)print(sum_of_numbers)  # 输出: 15

或者使用lambda表达式:

from functools import reduce# 使用 lambda 表达式和 reduce() 计算列表的乘积
numbers = [1, 2, 3, 4, 5]
product_of_numbers = reduce(lambda x, y: x * y, numbers)print(product_of_numbers)  # 输出: 120

使用 initializer

from functools import reduce# 使用 initializer 和 reduce() 计算列表的和,但初始值设为 10
numbers = [1, 2, 3, 4, 5]
sum_with_initializer = reduce(add, numbers, 10)print(sum_with_initializer)  # 输出: 25(10 + 1 + 2 + 3 + 4 + 5)
注意事项
  • reduce() 函数在 Python 3 中位于 functools 模块中,因此在使用前需要导入。
  • 提供的 function 必须接收两个参数,并且这两个参数的类型应该与 iterable 中的元素类型兼容。
  • 如果 iterable 为空且没有提供 initializerreduce() 会引发 TypeError
  • 如果提供了 initializer,它会在第一次调用 function 时作为第一个参数,这对于某些累计运算可能很有用。

自定义高阶函数

def with_logging(func):def wrapper(*args, **kwargs):print(f"Calling {func.__name__} with args {args} and kwargs {kwargs}")result = func(*args, **kwargs)print(f"{func.__name__} returned {result}")return resultreturn wrapper@with_logging  # 这是一个装饰器语法,等价于 square = with_logging(square)
def square(x):return x * xprint(square(4))  # 输出日志信息,并返回 16

在这个例子中,with_logging是一个高阶函数,它接受一个函数作为参数,并返回一个新的函数,这个新函数在执行原始函数之前和之后都会打印日志信息。通过使用装饰器语法@with_logging,我们可以方便地将这个高阶函数应用到其他函数上。

偏函数

偏函数(Partial Function)允许我们固定函数的某些参数,从而创建一个新的函数。这样做可以让我们在多次调用同一个函数时,避免重复传递那些不变的参数。Python标准库中的functools模块提供了partial函数来实现这一功能。

使用偏函数的好处

  1. 代码复用‌:通过固定某些参数,我们可以创建更加通用的函数,减少代码的重复。
  2. 提高可读性‌:偏函数可以让调用更加清晰,因为那些固定的参数不需要在每次调用时都显式地传递。
  3. 简化参数传递‌:当某个函数有多个参数,而其中的一些参数在多次调用中都不变时,使用偏函数可以简化调用。

functools.partial的使用

functools.partial的基本语法如下:

from functools import partial

创建一个偏函数
partial_func = partial(原始函数, 参数1, 参数2, …)

调用偏函数
result = partial_func(剩余参数1, 剩余参数2, …)

示例

假设我们有一个函数add,它接受两个参数ab,并返回它们的和。如果我们经常需要将某个固定的值加到不同的数上,我们可以使用偏函数来简化这个过程。

from functools import partial# 原始函数
def add(a, b):return a + b# 创建一个偏函数,固定参数a的值为5
add_five = partial(add, 5)# 使用偏函数
print(add_five(10))  # 输出15
print(add_five(20))  # 输出25

在这个例子中,add_five是一个偏函数,它将add函数的第一个参数a固定为5。因此,当我们调用add_five时,只需要传递一个参数,即b的值。

注意事项

  1. 参数顺序‌:在创建偏函数时,需要按照原始函数的参数顺序来传递那些要固定的参数。
  2. 剩余参数‌:偏函数创建后,调用时传递的参数会按顺序替换原始函数中未被固定的参数。
  3. 关键字参数‌:functools.partial也支持通过关键字参数来固定某些参数的值。例如,partial(func, a=1, b=2)会固定ab的值。

相关文章:

学习python的第十四天之函数——高阶函数和偏函数

学习python的第十四天之函数——高阶函数和偏函数 高阶函数 高阶函数是指那些可以接受一个或多个函数作为参数,或者返回一个函数作为结果的函数。高阶函数是函数式编程范式中的一个重要概念,它们使得代码更加灵活和模块化。 sorted() sorted()函数用于对…...

数据结构之二叉树详解:从原理到实现

1. 什么是二叉树? 二叉树(Binary Tree)是一种树形数据结构,其中每个节点最多有两个子节点,分别被称为左子节点和右子节点。二叉树可以用来表示层次关系,如文件目录、组织结构,或用于快速查找、…...

iOS 系统中使用 webView 打印 html 的打印边距问题

需求是使用系统提供的打印功能将HTML代码打印出来 1、使用CSS page 设置边距(iOS不生效) page {margin: 0;padding: 0;size: A6 portrait; }在 Android 中边距设置生效的,但是在 iOS 系统使用CSS page规则是不生效的 当从 iOS 系统打印网页…...

如何在ubuntu上调试core dump

启用core dump 确认ulimit 状态 ulimit -c 如果输出是0,表示core dump被禁用了 运行 ulimit -c unlimited 再次运行 ulimit -c 确认输出是ulimited 设置core dump路径和文件名格式 下面命令表示设置core dump文件在当前目录(%e表示程序名&#x…...

基于 JNI + Rust 实现一种高性能 Excel 导出方案(上篇)

每个不曾起舞的日子,都是对生命的辜负。 ——尼采 一、背景:Web 导出 Excel 的场景 Web 导出 Excel 功能在数据处理、分析和共享方面提供了极大的便利,是许多 Web 应用程序中的重要功能。以下是一些典型的场景: 数据报表导出&am…...

【Maven】依赖管理

4. Maven的依赖管理 在 Java 开发中,项目的依赖管理是一项重要任务。通过合理管理项目的依赖关系,我们可以有效的管理第三方库,模块的引用及版本控制。而 Maven 作为一个强大的构建工具和依赖管理工具,为我们提供了便捷的方式来管…...

springboot/ssm高校超市管理系统Java商品出入库供应商管理系统web源码wms

springboot/ssm高校超市管理系统Java商品出入库供应商管理系统web源码wms 基于springboot(可改ssm)vue项目 开发语言:Java 框架:springboot/可改ssm vue JDK版本:JDK1.8(或11) 服务器:tomcat 数据库&a…...

小程序-基于java+SpringBoot+Vue的微信小程序养老院系统设计与实现

项目运行 1.运行环境:最好是java jdk 1.8,我们在这个平台上运行的。其他版本理论上也可以。 2.IDE环境:IDEA,Eclipse,Myeclipse都可以。推荐IDEA; 3.tomcat环境:Tomcat 7.x,8.x,9.x版本均可 4.硬件环境&#xff1a…...

宠物电商对接美团闪购:实现快速配送与用户增值

随着宠物行业的快速发展,宠物电商市场也在不断扩张。消费者的需求不再局限于传统的线上购物模式,越来越多的人开始追求更快捷的配送服务和更优质的购物体验。为了适应这一趋势,许多宠物电商平台开始寻求与本地配送平台合作,以提供…...

Vue中使用<Transition>与<TransitionGroup>

目录 介绍 CSS过渡类 为过渡效果命名 CSS的transition CSS的transform 性能考量 出现时过渡 元素间过渡 过渡模式 使用Key属性过渡 和的区别 进入/离开动画 移动动画 一个购物车飞跃例子 介绍 传统HTML中,我们可以使用CSS属性:“animation”…...

Algorithms and Data Structures in C++ by Mohammed Yasir Eramangadan

MP4 创建 |视频:h264、1280720 |音频:AAC,44.1 KHz,2 通道 类型:在线学习 |语言:英文 字幕 |持续时间: 159 讲座 ( 10h 43m ) |大小: 3.5 GB “通过专家制作…...

2024广东省职业技能大赛云计算——构建CICD 部署2048小游戏

构建CI/CD 前言 题目如下: 构建CI/CD 编写流水线脚本.gitlab-ci.yml触发自动构建,具体要求如下: (1)基于镜像maven:3.6-jdk-8构建项目的drone分支; (2)构建镜像的名称&#xff1a…...

React 条件渲染

React 条件渲染 React 条件渲染是一种在 React 应用程序中根据不同的条件显示不同组件或内容的技巧。它是 React 响应用户输入、状态变化或数据变化的核心机制之一。本文将深入探讨 React 条件渲染的概念、用法和最佳实践。 目录 条件渲染的基本概念使用 JavaScript 运算符进…...

Hadoop生态圈框架部署(九)- Hive部署

文章目录 前言一、Hive部署(手动部署)下载Hive1. 上传安装包2. 解压Hive安装包2.1 解压2.2 重命名2.3 解决guava冲突 3. 配置Hive3.1 配置Hive环境变量3.2 修改 hive-site.xml 配置文件3.3 配置MySQL驱动包3.3.1 下在MySQL驱动包3.3.2 上传MySQL驱动包3.…...

c语言的qsort函数理解与使用

介绍:qsort 函数是 C 标准库中用于排序的快速排序算法函数。它的用法非常灵活,可以对任意类型的元素进行排序,只要提供了比较函数即可。 qsort 函数原型及参数解释: void qsort ( void* base, //指向要排序的数组的首元素…...

Java 语言的起源发展与基本概念(JDK,JRE,JVM)

Java语言的起源 源起 Java语言最初是由Sun Microsystems公司(该公司于2009年被Oracle公司收购)开发的一种编程语言。其创造者是詹姆斯高斯林(James Gosling),他是一位加拿大计算机科学家。其前身名为Oak(橡…...

03_变量

变量 var num 10; 变量的重新赋值 var num10; num 20; 变量提升 JavaScript 引擎的工作方式是,先解析代码,获取所有被声明的变量,然后再一行一行地运行。这造成的结果,就是所有的变量的声明语句,都会被提升到代码的…...

[论文阅读-综述]Supervised Speech Separation Based on Deep Learning: An Overview

基于深度学习的监督语音分离:综述 出版:IEEE 核心:使用语音分离将目标语音信号与噪声混合分离的计算 本文用于对该文章的学习,主要是对内容的理解翻译与笔记 1. 语音分离介绍 语音分离的目标:将目标语音与背景干扰分…...

群控系统服务端开发模式-应用开发-邮箱配置功能开发

邮箱配置主要是将管理员数据做归属。具体见下图: 一、创建表 1、语句 CREATE TABLE cluster_control.nc_param_mail (id int(11) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT 编号,title varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL COMMENT…...

【机器学习】——卷积与循环的交响曲:神经网络模型在现代科技中的协奏

🎼个人主页:【Y小夜】 😎作者简介:一位双非学校的大二学生,编程爱好者, 专注于基础和实战分享,欢迎私信咨询! 🎆入门专栏:🎇【MySQL&#xff0…...

android studio引用so库

在工程中编译好的so库文件将在原始编译工程对应目录下:build/intermediates/cxx/Debug/xxxxxx/obj/ 其目录结构如上所示,包含生成的四个版本,每个文件夹下均包含c/c源码编译成的Android版本的libnavi.so库和提供应用接口的libnavi-lib.so库。…...

2024年信号处理与神经网络应用(SPNNA 2024)

会议官网:www.spnna.org 会议时间:2024年12月13-15日 会议地点:中国武汉...

wxWidgets-ImageView

wxWidgets实现图片浏览、放大缩小、另存为新的图片格式等 #include "wx/wxprec.h"#ifndef WX_PRECOMP#include "wx/wx.h" #endif#include "wx/filename.h" #include "wx/zstream.h"#include "imageviewctrl.h"class MyFrame…...

第1章-JVM和Java体系架构

虚拟机 虚拟机概念 所谓虚拟机(Virtual Machine),就是一台虚拟的计算机。它是一款软件,用来执行一系列虚拟计算机指令。大体上,虚拟机可以分为系统虚拟机和程序虚拟机。 大名鼎鼎的Virtual Box,VMware就属…...

windows 服务器角色

windows 服务器角色 Active Directory Rights Management Services Active Directory RightsManagement Services (AD RS)帮助保护信息,防止未授权使用。AD RMS 将建立用户标识,并为授权用户提供受保护信息的许可证。 ServicesActive Directory 联合身…...

[OpenHarmony5.0][Docker][环境]OpenHarmony5.0 Docker编译环境镜像下载以及使用方式

T. 已测试目录 主机类型主机版本Docker镜像版本结果WSL2Ubuntu22.04Ubuntu20.04PASSWSL2Ubuntu22.04Ubuntu18.04PASS R. 软硬件要求: 编译硬件需求:做多系统测试,磁盘500GB起步(固态)(机械会卡死),内存3…...

C#中判断两个 List<T> 的内容是否相等

ET实现游戏中邮件系统逻辑思路(服务端)_游戏邮件系统设计-CSDN博客 场景:今天遇到一个BUG,在服务器重启的时候(体验服),玩家之前接收的邮件又重新接收了一次,但是两封邮件的ID是不同…...

Linux环境下配置neo4j图数据库

1.下载安装包 openjdk-11.0.1_linux-x64_bin.tar.gz neo4j-community-4.2.19-unix.tar.gz 2.之前配置好的配置文件 neo4j.conf 3.安装 3.1-jdk11的安装(jdk1.8不够用) 解压缩 tar -zxvf openjdk-11.0.1_linux-x64_bin.tar.gz修改系统环境变量 打开pro…...

Windows 11 搭建 Docker 桌面版详细教程

在当今的软件开发与部署领域,Docker 已成为一项极为重要的容器化技术。它能够让开发者轻松地打包应用及其依赖项,实现跨环境的一致性运行,大大提高了开发效率与部署的便捷性。本教程将详细介绍在 Windows 11 操作系统上搭建 Docker 桌面版的具…...

Pytest-Bdd-Playwright 系列教程(13):钩子(hooks)

Pytest-Bdd-Playwright 系列教程(13):钩子(hooks) 前言一、什么是钩子?二、Pytest-Bdd 提供的钩子一览三、钩子用法详解1. pytest_bdd_before_scenario2. pytest_bdd_after_scenario3. pytest_bdd_before_s…...

电子商务是干什么的就业前景/seo如何优化关键词

$output mb_convert_encoding($str, HTML-ENTITIES, $encode);$encode为输入的比如utf-8,因为utf-8可以包括英文,中文等字符,转换成gbk2312后,中文会显示乱码,所以都转换成原始码,页面可以直接读取汉字编码而不会出现…...

石家庄新闻综合频道在线直播观看/西安关键词优化软件

ios培训------我的c语言笔记&#xff0c;期待与您交流! #include <stdio.h> int main() {//逻辑与 条件1 && 条件2/*运算结果只有当条件A和条件B都成立时&#xff0c;结果才为1&#xff0c;也就是“真”&#xff1b;其余情况的结果都为0&#xff0c;也就是“假”…...

网页制作免费网站建设/管理培训

疑问&#xff1a;之前一直以为hashcode就是计算对象的内存地址&#xff0c;但是看其它博文又有说不是的&#xff0c;特此研究一下&#xff01; 先说结论&#xff1a;在JDK1.8中&#xff0c;hashcode和对象的内存地址没有必然关系&#xff0c;不是hashcode相等&#xff0c;他们…...

开发网站私活/关键字c语言

因为最近的多元统计讲到了聚类分析&#xff0c;课上同学也分别同&#xff32;、SPSS、python展示了简单的聚类。但是问题是&#xff0c;理论不够联系实际&#xff0c;具体说&#xff0c;就是我们没有结合具体的业务背景&#xff0c;甚至连数据清洗的环节也直接略过了&#xff0…...

东莞商业网站建设常识/下载app

Configuration cfg new Configuration().configure() ;SchemaExport export new SchemaExport(cfg);export.create(true, true);...

wordpress导航添加双语菜单/磁力兔子搜索引擎

步骤系列文章前言实现效果项目结构1.定义GSON实体类1.1gson包下建立一个Basic 类1.2gson包下建立一个AQI类1.3gson包下建立一个Now类1.4gson包下建立一个Suggestion类1.5gson包下建立一个Forecast类1.6gson包下建立一个Weather类2.编写天气界面2.1新建一个title.xml2.2新建一个…...