开个贴,用于记录平时经常碰到的Python的错误同时对导致错误的原因进行分析,并持续更新,方便以后查询,学习。
知识在于积累嘛!微笑
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
错误:
复制代码 代码如下:
def f(x, y):
print x, y
t = ('a', 'b')
f(t)
Traceback (most recent call last):
File "<pyshell#65>", line 1, in
f(t)
TypeError: f() takes exactly 2 arguments (1 given)
【错误分析】不要误以为元祖里有两个参数,将元祖传进去就可以了,实际上元祖作为一个整体只是一个参数,
实际需要两个参数,所以报错。必需再传一个参数方可.
复制代码 代码如下:
f(t, 'var2')
('a', 'b') var2
更常用的用法: 在前面加*,代表引用元祖
复制代码 代码如下:
f(*t)
'a', 'b'
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
错误:
复制代码 代码如下:
def func(y=2, x):
return x + y
SyntaxError: non-default argument follows default argument
【错误分析】在C++,Python中默认参数从左往右防止,而不是相反。这可能跟参数进栈顺序有关。
复制代码 代码如下:
def func(x, y=2):
return x + y
func(1)
3
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
错误:
复制代码 代码如下:
D1 = {'x':1, 'y':2}
D1['x']
1
D1['z']
Traceback (most recent call last):
File "<pyshell#185>", line 1, in
D1['z']
KeyError: 'z'
【错误分析】这是Python中字典键错误的提示,如果想让程序继续运行,可以用字典中的get方法,如果键存在,则获取该键对应的值,不存在的,返回None,也可打印提示信息.
复制代码 代码如下:
D1.get('z', 'Key Not Exist!')
'Key Not Exist!'
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
错误:
复制代码 代码如下:
from math import sqrt
exec "sqrt = 1"
sqrt(4)
Traceback (most recent call last):
File "<pyshell#22>", line 1, in
sqrt(4)
TypeError: 'int' object is not callable
【错误分析】exec语句最有用的地方在于动态地创建代码字符串,但里面存在的潜在的风险,它会执行其他地方的字符串,在CGI中更是如此!比如例子中的sqrt = 1,从而改变了当前的命名空间,从math模块中导入的sqrt不再和函数名绑定而是成为了一个整数。要避免这种情况,可以通过增加in
复制代码 代码如下:
from math import sqrt
scope = {}
exec "sqrt = 1" in scope
sqrt(4)
2.0
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
错误:
复制代码 代码如下:
seq = [1, 2, 3, 4]
sep = '+'
sep.join(seq)
Traceback (most recent call last):
File "<pyshell#25>", line 1, in
sep.join(seq)
TypeError: sequence item 0: expected string, int found
【错误分析】join是split的逆方法,是非常重要的字符串方法,但不能用来连接整数型列表,所以需要改成:
复制代码 代码如下:
seq = ['1', '2', '3', '4']
sep = '+'
sep.join(seq)
'1+2+3+4'
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
错误:
复制代码 代码如下:
print r'C:\Program Files\foo\bar\'
SyntaxError: EOL while scanning string literal
【错误分析】Python中原始字符串以r开头,里面可以放置任意原始字符,包括\,包含在字符中的\不做转义。
但是,不能放在末尾!也就是说,最后一个字符不能是\,如果真 需要的话,可以这样写:
复制代码 代码如下:
print r'C:\Program Files\foo\bar' "\\"
C:\Program Files\foo\bar\
print r'C:\Program Files\foo\bar' + "\\"
C:\Program Files\foo\bar\
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
代码:
复制代码 代码如下:
bad = 'bad'
try:
raise bad
except bad:
print 'Got Bad!'
错误:
复制代码 代码如下:
Traceback (most recent call last):
File "D:\Learn\Python\Learn.py", line 4, in
raise bad
TypeError: exceptions must be old-style classes or derived from BaseException, not str
【错误分析】因所用的Python版本2.7,比较高的版本,raise触发的异常,只能是自定义类异常,而不能是字符串。所以会报错,字符串改为自定义类,就可以了。
复制代码 代码如下:
class Bad(Exception):
pass
def raiseException():
raise Bad()
try:
raiseException()
except Bad:
print 'Got Bad!'
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
复制代码 代码如下:
class Super:
def method(self):
print "Super's method"
class Sub(Super):
def method(self):
print "Sub's method"
Super.method()
print "Over..."
S = Sub()
S.method()
执行上面一段代码,错误如下:
复制代码 代码如下:
Sub's method
Traceback (most recent call last):
File "D:\Learn\Python\test.py", line 12, in
S.method()
File "D:\Learn\Python\test.py", line 8, in method
Super.method()
TypeError: unbound method method() must be called with Super instance as first argument (got nothing instead)
【错误分析】Python中调用类的方法,必须与实例绑定,或者调用自身.
复制代码 代码如下:
ClassName.method(x, 'Parm')
ClassName.method(self)
所以上面代码,要调用Super类的话,只需要加个self参数即可。
复制代码 代码如下:
class Super:
def method(self):
print "Super's method"
class Sub(Super):
def method(self):
print "Sub's method"
Super.method(self)
print "Over..."
S = Sub()
S.method()
Sub's method
Super's method
Over...
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
复制代码 代码如下:
reload(sys)
Traceback (most recent call last):
File "", line 1, in
NameError: name 'sys' is not defined
【错误分析】reload期望得到的是对象,所以该模块必须成功导入。在没导入模块前,不能重载.
复制代码 代码如下:
import sys
reload(sys)
<module 'sys' (built-in)>
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
复制代码 代码如下:
def f(x, y, z):
return x + y + z
args = (1,2,3)
print f(args)
Traceback (most recent call last):
File "<pyshell#6>", line 1, in
print f(args)
TypeError: f() takes exactly 3 arguments (1 given)
【错误分析】args是一个元祖,如果是f(args),那么元祖是作为一个整体作为一个参数
*args,才是将元祖中的每个元素作为参数
复制代码 代码如下:
f(*args)
6
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
复制代码 代码如下:
def f(a,b,c,d):
... print a,b,c,d
...
args = (1,2,3,4)
f(args)
Traceback (most recent call last):
File "", line 1, in must be a mapping, not tuple
TypeError: f() argument after
【错误分析】错误原因**匹配并收集在字典中所有包含位置的参数,但传递进去的却是个元祖。
所以修改传递参数如下:
复制代码 代码如下:
args = {'a':1,'b':2,'c':3}
args['d'] = 4
f(**args)
1 2 3 4
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
【错误分析】在函数hider()内使用了内置变量open,但根据Python作用域规则LEGB的优先级:
先是查找本地变量==》模块内的其他函数==》全局变量==》内置变量,查到了即停止查找。
所以open在这里只是个字符串,不能作为打开文件来使用,所以报错,更改变量名即可。
可以导入builtin模块看到所有内置变量:异常错误、和内置方法
复制代码 代码如下:
import builtin
dir(builtin)
['ArithmeticError', 'AssertionError', 'AttributeError',..
.........................................zip,filter,map]
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
复制代码 代码如下:
In [105]: T1 = (1)
In [106]: T2 = (2,3)
In [107]: T1 + T2
---------------------------------------------------------------------------
TypeError Traceback (most recent call last)
TypeError: unsupported operand type(s) for +: 'int' and 'tuple'
【错误分析】(1)的类型是整数,所以不能与另一个元祖做合并操作,如果只有一个元素的元祖,应该用(1,)来表示
复制代码 代码如下:
In [108]: type(T1)
Out[108]: int
In [109]: T1 = (1,)
In [110]: T2 = (2,3)
In [111]: T1 + T2
Out[111]: (1, 2, 3)
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
复制代码 代码如下:
hash(1,(2,[3,4]))
Traceback (most recent call last):
File "<pyshell#95>", line 1, in
hash((1,2,(2,[3,4])))
TypeError: unhashable type: 'list'
【错误分析】字典中的键必须是不可变对象,如(整数,浮点数,字符串,元祖).
可用hash()判断某个对象是否可哈希
复制代码 代码如下:
hash('string')
-1542666171
但列表中元素是可变对象,所以是不可哈希的,所以会报上面的错误.
如果要用列表作为字典中的键,最简单的办法是:
复制代码 代码如下:
D = {}
D[tuple([3,4])] = 5
D
{(3, 4): 5}
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
复制代码 代码如下:
L = [2,1,4,3]
L.reverse().sort()
Traceback (most recent call last):
File "", line 1, in
AttributeError: 'NoneType' object has no attribute 'sort'
L
[3, 4, 1, 2]
【错误分析】列表属于可变对象,其append(),sort(),reverse()会在原处修改对象,不会有返回值,
或者说返回值为空,所以要实现反转并排序,不能并行操作,要分开来写
复制代码 代码如下:
L = [2,1,4,3]
L.reverse()
L.sort()
L
[1, 2, 3, 4]
或者用下面的方法实现:
复制代码 代码如下:
In [103]: sorted(reversed([2,1,4,3]))
Out[103]: [1, 2, 3, 4]
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
复制代码 代码如下:
class = 78
SyntaxError: invalid syntax
【错误分析】class是Python保留字,Python保留字不能做变量名,可以用Class,或klass
同样,保留字不能作为模块名来导入,比如说,有个and.py,但不能将其作为模块导入
复制代码 代码如下:
import and
SyntaxError: invalid syntax
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
复制代码 代码如下:
f = open('D:\new\text.data','r')
Traceback (most recent call last):
File "", line 1, in
IOError: [Errno 22] invalid mode ('r') or filename: 'D:\new\text.data'
f = open(r'D:\new\text.data','r')
f.read()
'Very\ngood\naaaaa'
【错误分析】\n默认为换行,\t默认为TAB键.
所以在D:\目录下找不到ew目录下的ext.data文件,将其改为raw方式输入即可。
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
复制代码 代码如下:
try:
print 1 / 0
except ZeroDivisionError:
print 'integer division or modulo by zero'
finally:
print 'Done'
else:
print 'Continue Handle other part'
报错如下:
D:>python Learn.py
File "Learn.py", line 11
else:
^
SyntaxError: invalid syntax
【错误分析】错误原因,else, finally执行位置;正确的程序应该如下:
复制代码 代码如下:
try:
print 1 / 0
except ZeroDivisionError:
print 'integer division or modulo by zero'
else:
print 'Continue Handle other part'
finally:
print 'Done'
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
复制代码 代码如下:
[x,y for x in range(2) for y in range(3)]
File "", line 1
[x,y for x in range(2) for y in range(3)]
^
SyntaxError: invalid syntax
【错误分析】错误原因,列表解析中,x,y必须以数组的方式列出(x,y)
复制代码 代码如下:
[(x,y) for x in range(2) for y in range(3)]
[(0, 0), (0, 1), (0, 2), (1, 0), (1, 1), (1, 2)]
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
class JustCounter:
__secretCount = 0
def count(self):
self.__secretCount += 1
print 'secretCount is:', self.__secretCount
count1 = JustCounter()
count1.count()
count1.count()
count1.__secretCount
报错如下:
复制代码 代码如下:
secretCount is: 1
secretCount is: 2
Traceback (most recent call last):
File "D:\Learn\Python\Learn.py", line 13, in
count1.secretCount
AttributeError: JustCounter instance has no attribute 'secretCount'
【错误分析】双下划线的类属性__secretCount不可访问,所以会报无此属性的错误.
解决办法如下:
复制代码 代码如下:
ClassName._ClassName__Attr
ClassInstance._ClassName__Attr
print count1._JustCounter__secretCount
print JustCounter._JustCounter__secretCount
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
复制代码 代码如下:
print x
Traceback (most recent call last):
File "", line 1, in
NameError: name 'x' is not defined
x = 1
print x
1
【错误分析】Python不允许使用未赋值变量
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
复制代码 代码如下:
t = (1,2)
t.append(3)
Traceback (most recent call last):
File "", line 1, in
AttributeError: 'tuple' object has no attribute 'append'
t.remove(2)
Traceback (most recent call last):
File "", line 1, in
AttributeError: 'tuple' object has no attribute 'remove'
t.pop()
Traceback (most recent call last):
File "", line 1, in
AttributeError: 'tuple' object has no attribute 'pop'
【错误分析】属性错误,归根到底在于元祖是不可变类型,所以没有这几种方法.
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
复制代码 代码如下:
t = ()
t[0]
Traceback (most recent call last):
File "", line 1, in
IndexError: tuple index out of range
l = []
l[0]
Traceback (most recent call last):
File "", line 1, in
IndexError: list index out of range
【错误分析】空元祖和空列表,没有索引为0的项
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
复制代码 代码如下:
if X>Y:
... X,Y = 3,4
... print X,Y
File "", line 3
print X,Y
^
IndentationError: unexpected indent
t = (1,2,3,4)
File "", line 1
t = (1,2,3,4)
^
IndentationError: unexpected indent
【错误分析】一般出在代码缩进的问题
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
复制代码 代码如下:
f = file('1.txt')
f.readline()
'AAAAA\n'
f.readline()
'BBBBB\n'
f.next()
'CCCCC\n'
【错误分析】如果文件里面没有行了会报这种异常
复制代码 代码如下:
f.next() #
Traceback (most recent call last):
File "", line 1, in
StopIteration
有可迭代的对象的next方法,会前进到下一个结果,而在一系列结果的末尾时,会引发StopIteration的异常.
next()方法属于Python的魔法方法,这种方法的效果就是:逐行读取文本文件的最佳方式就是根本不要去读取。
取而代之的用for循环去遍历文件,自动调用next()去调用每一行,且不会报错
复制代码 代码如下:
for line in open('test.txt','r'):
print line
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
复制代码 代码如下:
string = 'SPAM'
a,b,c = string
Traceback (most recent call last):
File "", line 1, in
ValueError: too many values to unpack
【错误分析】接受的变量少了,应该是
复制代码 代码如下:
a,b,c,d = string
a,d
('S', 'M')除非用切片的方式
a,b,c = string[0],string[1],string[2:]
a,b,c
('S', 'P', 'AM')
或者
a,b,c = list(string[:2]) + [string[2:]]
a,b,c
('S', 'P', 'AM')
或者
(a,b),c = string[:2],string[2:]
a,b,c
('S', 'P', 'AM')
或者
((a,b),c) = ('SP','AM')
a,b,c
('S', 'P', 'AM')
简单点就是:
a,b = string[:2]
c = string[2:]
a,b,c
('S', 'P', 'AM')
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
复制代码 代码如下:
mydic={'a':1,'b':2}
mydic['a']
1
mydic['c']
Traceback (most recent call last):
File "", line 1, in ?
KeyError: 'c'
【错误分析】当映射到字典中的键不存在时候,就会触发此类异常, 或者可以,这样测试
复制代码 代码如下:
'a' in mydic.keys()
True
'c' in mydic.keys() #用in做成员归属测试
False
D.get('c','"c" is not exist!') #用get或获取键,如不存在,会打印后面给出的错误信息
'"c" is not exist!'
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
复制代码 代码如下:
File "study.py", line 3
return None
^
dentationError: unexpected indent
【错误分析】一般是代码缩进问题,TAB键或空格键不一致导致
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
复制代码 代码如下:
def A():
return A()
A() #无限循环,等消耗掉所有内存资源后,报最大递归深度的错误
File "<pyshell#2>", line 2, in A return A()RuntimeError: maximum recursion depth exceeded
class Bird:
def init(self):
self.hungry = True
def eat(self):
if self.hungry:
print "Ahaha..."
self.hungry = False
else:
print "No, Thanks!"
该类定义鸟的基本功能吃,吃饱了就不再吃
输出结果:
复制代码 代码如下:
b = Bird()
b.eat()
Ahaha...
b.eat()
No, Thanks!
下面一个子类SingBird,
复制代码 代码如下:
class SingBird(Bird):
def init(self):
self.sound = 'squawk'
def sing(self):
print self.sound
输出结果:
复制代码 代码如下:
s = SingBird()
s.sing()
squawk
SingBird是Bird的子类,但如果调用Bird类的eat()方法时,
复制代码 代码如下:
s.eat()
Traceback (most recent call last):
File "<pyshell#5>", line 1, in
s.eat()
File "D:\Learn\Python\Person.py", line 42, in eat
if self.hungry:
AttributeError: SingBird instance has no attribute 'hungry'
【错误分析】代码错误很清晰,SingBird中初始化代码被重写,但没有任何初始化hungry的代码
复制代码 代码如下:
class SingBird(Bird):
def init(self):
self.sound = 'squawk'
self.hungry = Ture #加这么一句
def sing(self):
print self.sound
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
复制代码 代码如下:
class Bird:
def init(self):
self.hungry = True
def eat(self):
if self.hungry:
print "Ahaha..."
self.hungry = False
else:
print "No, Thanks!"
class SingBird(Bird):
def init(self):
super(SingBird,self).init()
self.sound = 'squawk'
def sing(self):
print self.sound
sb = SingBird()
Traceback (most recent call last):
File "<pyshell#5>", line 1, in
sb = SingBird()
File "D:\Learn\Python\Person.py", line 51, in init
super(SingBird,self).init()
TypeError: must be type, not classobj
【错误分析】在模块首行里面加上metaclass=type,具体还没搞清楚为什么要加
复制代码 代码如下:
metaclass=type
class Bird:
def init(self):
self.hungry = True
def eat(self):
if self.hungry:
print "Ahaha..."
self.hungry = False
else:
print "No, Thanks!"
class SingBird(Bird):
def init(self):
super(SingBird,self).init()
self.sound = 'squawk'
def sing(self):
print self.sound
S = SingBird()
S.
SyntaxError: invalid syntax
S.
SyntaxError: invalid syntax
S.eat()
Ahaha...
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
复制代码 代码如下:
T
(1, 2, 3, 4)
T[0] = 22
Traceback (most recent call last):
File "<pyshell#129>", line 1, in
T[0] = 22
TypeError: 'tuple' object does not support item assignment
【错误分析】元祖不可变,所以不可以更改;可以用切片或合并的方式达到目的.
复制代码 代码如下:
T = (1,2,3,4)
(22,) + T[1:]
(22, 2, 3, 4)
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
复制代码 代码如下:
X = 1;
Y = 2;
X + = Y
File "", line 1
X + = Y
^
SyntaxError: invalid syntax
【错误分析】增强行赋值不能分开来写,必须连着写比如说 +=, *=
复制代码 代码如下:
X += Y
X;Y
3
2
京东创始人刘强东和其妻子章泽天最近成为了互联网舆论关注的焦点。有关他们“移民美国”和在美国购买豪宅的传言在互联网上广泛传播。然而,京东官方通过微博发言人发布的消息澄清了这些传言,称这些言论纯属虚假信息和蓄意捏造。
日前,据博主“@超能数码君老周”爆料,国内三大运营商中国移动、中国电信和中国联通预计将集体采购百万台规模的华为Mate60系列手机。
据报道,荷兰半导体设备公司ASML正看到美国对华遏制政策的负面影响。阿斯麦(ASML)CEO彼得·温宁克在一档电视节目中分享了他对中国大陆问题以及该公司面临的出口管制和保护主义的看法。彼得曾在多个场合表达了他对出口管制以及中荷经济关系的担忧。
今年早些时候,抖音悄然上线了一款名为“青桃”的 App,Slogan 为“看见你的热爱”,根据应用介绍可知,“青桃”是一个属于年轻人的兴趣知识视频平台,由抖音官方出品的中长视频关联版本,整体风格有些类似B站。
日前,威马汽车首席数据官梅松林转发了一份“世界各国地区拥车率排行榜”,同时,他发文表示:中国汽车普及率低于非洲国家尼日利亚,每百户家庭仅17户有车。意大利世界排名第一,每十户中九户有车。
近日,一项新的研究发现,维生素 C 和 E 等抗氧化剂会激活一种机制,刺激癌症肿瘤中新血管的生长,帮助它们生长和扩散。
据媒体援引消息人士报道,苹果公司正在测试使用3D打印技术来生产其智能手表的钢质底盘。消息传出后,3D系统一度大涨超10%,不过截至周三收盘,该股涨幅回落至2%以内。
9月2日,坐拥千万粉丝的网红主播“秀才”账号被封禁,在社交媒体平台上引发热议。平台相关负责人表示,“秀才”账号违反平台相关规定,已封禁。据知情人士透露,秀才近期被举报存在违法行为,这可能是他被封禁的部分原因。据悉,“秀才”年龄39岁,是安徽省亳州市蒙城县人,抖音网红,粉丝数量超1200万。他曾被称为“中老年...
9月3日消息,亚马逊的一些股东,包括持有该公司股票的一家养老基金,日前对亚马逊、其创始人贝索斯和其董事会提起诉讼,指控他们在为 Project Kuiper 卫星星座项目购买发射服务时“违反了信义义务”。
据消息,为推广自家应用,苹果现推出了一个名为“Apps by Apple”的网站,展示了苹果为旗下产品(如 iPhone、iPad、Apple Watch、Mac 和 Apple TV)开发的各种应用程序。
特斯拉本周在美国大幅下调Model S和X售价,引发了该公司一些最坚定支持者的不满。知名特斯拉多头、未来基金(Future Fund)管理合伙人加里·布莱克发帖称,降价是一种“短期麻醉剂”,会让潜在客户等待进一步降价。
据外媒9月2日报道,荷兰半导体设备制造商阿斯麦称,尽管荷兰政府颁布的半导体设备出口管制新规9月正式生效,但该公司已获得在2023年底以前向中国运送受限制芯片制造机器的许可。
近日,根据美国证券交易委员会的文件显示,苹果卫星服务提供商 Globalstar 近期向马斯克旗下的 SpaceX 支付 6400 万美元(约 4.65 亿元人民币)。用于在 2023-2025 年期间,发射卫星,进一步扩展苹果 iPhone 系列的 SOS 卫星服务。
据报道,马斯克旗下社交平台𝕏(推特)日前调整了隐私政策,允许 𝕏 使用用户发布的信息来训练其人工智能(AI)模型。新的隐私政策将于 9 月 29 日生效。新政策规定,𝕏可能会使用所收集到的平台信息和公开可用的信息,来帮助训练 𝕏 的机器学习或人工智能模型。
9月2日,荣耀CEO赵明在采访中谈及华为手机回归时表示,替老同事们高兴,觉得手机行业,由于华为的回归,让竞争充满了更多的可能性和更多的魅力,对行业来说也是件好事。
《自然》30日发表的一篇论文报道了一个名为Swift的人工智能(AI)系统,该系统驾驶无人机的能力可在真实世界中一对一冠军赛里战胜人类对手。
近日,非营利组织纽约真菌学会(NYMS)发出警告,表示亚马逊为代表的电商平台上,充斥着各种AI生成的蘑菇觅食科普书籍,其中存在诸多错误。
社交媒体平台𝕏(原推特)新隐私政策提到:“在您同意的情况下,我们可能出于安全、安保和身份识别目的收集和使用您的生物识别信息。”
2023年德国柏林消费电子展上,各大企业都带来了最新的理念和产品,而高端化、本土化的中国产品正在不断吸引欧洲等国际市场的目光。
罗永浩日前在直播中吐槽苹果即将推出的 iPhone 新品,具体内容为:“以我对我‘子公司’的了解,我认为 iPhone 15 跟 iPhone 14 不会有什么区别的,除了序(列)号变了,这个‘不要脸’的东西,这个‘臭厨子’。