有一道ctf题为:ASCII码而已

1
\u5927\u5bb6\u597d\uff0c\u6211\u662f\u0040\u65e0\u6240\u4e0d\u80fd\u7684\u9b42\u5927\u4eba\uff01\u8bdd\u8bf4\u5fae\u535a\u7c89\u4e1d\u8fc7\u767e\u771f\u7684\u597d\u96be\u3002\u3002\u0077\u0063\u0074\u0066\u007b\u006d\u006f\u0072\u0065\u006d\u006f\u0072\u0065\u005f\u0077\u0065\u0069\u0062\u006f\u005f\u0066\u0061\u006e\u0073\u007d

这是Unicode编码,题目是ASCII码xx,猜到题意:将Unicode码转换成ASCII码。 我用Python进行转换。

wKioL1ihuU3is7FoAATZz4GYgAY155.png

一个简单的ctf题,我将print函数进行总结。

在 Python 3 中接触的第一个很大的差异就是缩进是作为语法的一部分,这和C++等其他语言确实很不一样,所以要小心 ,其中python3和python2中print的用法有很多不同,python3中需要使用括号

缩进要使用4个空格(这不是必须的,但你最好这么做),缩进表示一个代码块的开始,非缩进表示一个代码的结束。没有明确的大括号、中括号、或者关键字。这意味着空白很重要,而且必须要是一致的。第一个没有缩进的行标记了代码块,意思是指函数,if 语句、 for 循环、 while 循环等等的结束。

输入很简单

      1. x = input("Please input x:")  

      2. Please input x:

输出的 print 函数总结:

1. 字符串和数值类型
可以直接输出

      1. >>> print(1)  

      2. 1  

      3. >>> print("Hello World")  

      4. Hello World  


2.变量
无论什么类型,数值,布尔,列表,字典...都可以直接输出

 

 

  1. >>> x = 12  

  2. >>> print(x)  

  3. 12  

  4. >>> s = 'Hello'  

  5. >>> print(s)  

  6. Hello  

  7. >>> L = [1,2,'a']  

  8. >>> print(L)  

  9. [1, 2, 'a']  

  10. >>> t = (1,2,'a')  

  11. >>> print(t)  

  12. (1, 2, 'a')  

  13. >>> d = {'a':1, 'b':2}  

  14. >>> print(d)  

  15. {'a': 1, 'b': 2}  


3.格式化输出
类似于C中的 printf

 

 

  1. >>> s  

  2. 'Hello'  

  3. >>> x = len(s)  

  4. >>> print("The length of %s is %d" % (s,x))  

  5. The length of Hello is 5  



 

(1). %字符:标记转换说明符的开始


(2). 转换标志:-表示左对齐;+表示在转换值之前要加上正负号;“”(空白字符)表示正数之前保留空格;0表示转换值若位数不够则用0填充


(3). 最小字段宽度:转换后的字符串至少应该具有该值指定的宽度。如果是*,则宽度会从值元组中读出。


(4). 点(.)后跟精度值:如果转换的是实数,精度值就表示出现在小数点后的位数。如果转换的是字符串,那么该数字就表示最大字段宽度。如果是*,那么精度将从元组中读出

 

(5).字符串格式化转换类型


转换类型          含义

d,i                 带符号的十进制整数
o                   不带符号的八进制
u                   不带符号的十进制
x                    不带符号的十六进制(小写)
X                   不带符号的十六进制(大写)
e                   科学计数法表示的浮点数(小写)
E                   科学计数法表示的浮点数(大写)
f,F                 十进制浮点数
g                   如果指数大于-4或者小于精度值则和e相同,其他情况和f相同
G                  如果指数大于-4或者小于精度值则和E相同,其他情况和F相同
C                  单字符(接受整数或者单字符字符串)
r                    字符串(使用repr转换任意python对象)
s                   字符串(使用str转换任意python对象)

 

  1. >>> pi = 3.141592653  

  2. >>> print('%10.3f' % pi) #字段宽10,精度3  

  3.      3.142  

  4. >>> print("pi = %.*f" % (3,pi)) #用*从后面的元组中读取字段宽度或精度  

  5. pi = 3.142  

  6. >>> print('%010.3f' % pi) #用0填充空白  

  7. 000003.142  

  8. >>> print('%-10.3f' % pi) #左对齐  

  9. 3.142       

  10. >>> print('%+f' % pi) #显示正负号  

  11. +3.141593  


4.如何让 print 不换行
在Python中总是默认换行的

 

 

  1. >>> for x in range(0,10):  

  2.     print(x)  

  3.   

  4.       

  5. 0  

  6. 1  

  7. 2  

  8. 3  

  9. 4  

  10. 5  

  11. 6  

  12. 7  

  13. 8  

  14. 9  


如果想要不换行,之前的 2.x 版本可以这样 print x, 在末尾加上 ,
但在 3.x 中这样不起任何作用
要想换行你应该写成 print(x,end = '' )

 

 

  1. >>> for x in range(0,10):  

  2.     print (x,end = '')  

  3.   

  4.       

  5. 0123456789  



 

 

拼接字符串:

 

  1. >>> "Hello""World"  

  2. 'HelloWorld'  

  3. >>> x = "Hello"  

  4. >>> y = "world"  

  5. >>> xy  

  6. Traceback (most recent call last):  

  7.   File "<pyshell#10>", line 1, in <module>  

  8.     xy  

  9. NameError: name 'xy' is not defined  

  10. >>> x+y  

  11. 'Helloworld'  

 

 

pow函数:

  1. # 2**3%5(2的3次幂对5取模)  

  2. >>> pow(2,3,5)  

  3. 3  


然后很重要一点是类型可以自由地转换,你赋什么值,变量就是什么类型,python会自动帮你管理

这点真让我的C++思维转不过来呢

 

  1. >>> x = 2  

  2. >>> type(x)  

  3. <class 'int'>  

  4. >>> x = 2.3  

  5. >>> type(x)  

  6. <class 'float'>  

  7. >>> x = [2,3]  

  8. >>> type(x)  

  9. <class 'list'>  


部分函数:

 

abs(number),返回数字的绝对值

cmath.sqrt(number),返回平方根,也可以应用于负数

float(object),把字符串和数字转换为浮点数

help(),提供交互式帮助

input(prompt),获取用户输入

int(object),把字符串和数字转换为整数

math.ceil(number),返回数的上入整数,返回值的类型为浮点数

math.floor(number),返回数的下舍整数,返回值的类型为浮点数

math.sqrt(number),返回平方根不适用于负数

pow(x,y[.z]),返回X的y次幂(有z则对z取模)

repr(object),返回值的字符串标示形式

round(number[.ndigits]),根据给定的精度对数字进行四舍五入

str(object),把值转换为字符串