Python 实现一个颜色色值转换的小工具

  需求说明

  公司的 UI 设计小哥,已经转用 Zeplin 很久了。Zeplin 的设计稿展示页面的颜色色值使用十进制的 RGB 表示的,在 Android 中的颜色表示大多情况下都需要十六进制的 RGB 表示。我的数学没有好到直接看到十进制就可以心算得到十六进制的结果,所以我需要一个工具,输入十进制的 RGB ,得到十六进制的色值,最好可以方便复制。

Zeplin 的颜色色值显示示例

  原有处理方式

  因为我会 Python (仅限于终端输入 python 然后当做计算器算,或者用 hex() 函数把十进制转换成十六进制),所以遇到这样的问题我当然是采用python 的 hex() 函数做转换,然后手动结果输入到 Android Studio 中。

采用 hex 函数手动转换色值

  动机

  人总是懒得,想要写这个小工具已经很久了,我也打过有过构思就是:

  输入: 类似 RGB 的十进制值(110, 122 138),用空格或者逗号分割一下。

  输出: 一个十六进制的 RGB 颜色色值(#6e7a8a)。

  但就一直没动手,一直讲究着。真懒!

  开干

  1.首先我需要输入函数

  我打开我之前学习 Python 的文件夹,里面正好有一个 raw_input 的示例:

Python代码

#!/usr/bin/python 

#coding=utf-8 

raw_input("\n\n等输入")

  在终端执行 python input.py 后, 可以输入文字。

  我需要接受到用户输入的信息。怎么接收忘记了, Google 之,得到结果,顺便改改输入提示语,打印出输入的内容:

Python代码

input = raw_input("\n输入颜色 比如50 144 60:\n")
print(input) 

  2. 需要分割字符

  查询到python 字符分割函数 split(),默认不传入参数就可以用空白符分割。原本还说用英文逗号(,)作为分隔符,现在看来可以省了,直接用空格分割,无论多少空格都可以自动分割。于是加上代码:

Python代码

rgbColorArray = input.split()
print(rgbColorArray)

  3. 需要遍历数组

  简单的遍历数组的是怎么弄的也忘记了,同样搜索:

Python代码

for x in rgbColorArray: print(x) 

  4. 字符转成十六进制

  这个时候拿到了字符串,要变成十六进制的字符串。这个时候需要两个函数, int() 和 hex(),int 函数可以将字符串转成 int 类型,而 hex 则接受数字参数,返回字符串。 0x开始的字符串。

  于是就有了版的。

于是就有了第一个版本。

  第一个版本

第一个版本

第一个版本执行结果

  写出这样的基础版本已经基本可以得到我想要的结果了,缺点是还需要我手动收入,动用大脑记忆十六进制色值然后输入。希望可以直接复制最后结果。

  再进一步

  虽然结果已经出来了,但是还是希望可以在进步一些,有几个问题:

  1. 当要转换的数字小于16的时候 只有一位不显示,比如11 显示的结果是0xB

  2. 现实的结果多了0x

  3. 显示的结果最好连在一起方便复制,而不是每个颜色一行。

  那么就需要遍历颜色值数组,去掉0x 字符串, 判断小于16的前面补上0。连续在一起输出结果。

  for 循环遍历数组

  前面用到了 for 循环,是从查到的范例,不过多行就不知道怎么弄了。java 写多了一般都是 { } 大括号括起来。

  继续查资料,于是知道是大概下面这样的用法。

Python代码

#!/usr/bin/python
# -*- coding: UTF-8 -*- 

for num in range(10,20): # 迭代 10 到 20 之间的数字
 for i in range(2,num): # 根据因子迭代
  if num%i == 0:  # 确定第一个因子
   j=num/i   # 计算第二个因子
   print '%d 等于 %d * %d' % (num,i,j)
   break   # 跳出当前循环
 else:     # 循环的 else 部分
  print num, '是一个质数'

  变量声明

  由于需要不换行,所以就需要字符连接,而不是直接 print。

  声明变量又遇到问题了。根据前面的变量使用情况,找了些 python 代码看了看,大概知道不用声明什么类型,直接用就好了。于是有了代码:

Python代码

output = "#"
for x in rgbColorArray:
 intx = int(x)
 output = output + hex(intx)
print(output)

  字符串裁剪和拼接

  需要把多余的0x 两位去掉。

  用到字符串裁剪,依然寻找范例。

Python代码

#!/usr/bin/python 

var1 = 'Hello World!'
var2 = "Python Runoob" 

print "var1[0]: ", var1[0]
print "var2[1:5]: ", var2[1:5]

  这个范例的执行结果:

Python代码

var1[0]: H
var2[1:5]: ytho

  顺便问了旁边也在学习 python 的同事,他告诉我后面的索引可以省略,代表直接裁剪到结尾。

  比如上面的例子如果 print "var2[1:]", var2[1:] 得到的结果应该是 ython Runoob

  所以有代码:

Python代码

output = "#"
for x in rgbColorArray:
 intx = int(x)
 output = output + hex(intx)[2:]
print(output)

  也可以从后往前数,比如还是上面的范例可以写成。比如上面的例子如果 print "var2[-1:]", var2[-1:] 得到的结果应该是 ob 也就是字符串的后两位。

  于是我们这里可以写成hex(intx)[-2:] (因为输出字符串类似是0x23, 这样的)就是这个导致我后面写了个 bug,我也文章最后说明这个 bug 是什么。

  if else 判断

  接着要做一个判断,给一位的补上0

Python代码

if intx < 16:
 output = output + '0' + hex(intx)[-2:]
else:
 output = output + hex(intx)[-2:]

  这样就有了python 文件:

Python代码

#!/usr/bin/python
#coding=utf-8 

input = raw_input("\n输入颜色 比如50 144 60:\n")
#print(input) 

rgbColorArray = input.split()
print(rgbColorArray) 

output = "#"
for x in rgbColorArray:
 intx = int(x)
 if intx < 16:
  output = output + '0' + hex(intx)[-2:]
 else:
  output = output + hex(intx)[-2:]
#print(hex(int(x)))
print(output)

  还有最后一步:把 ColorU 加入到环境变量中

  这个时候我可以得到我要的记过了,但是有点不太方便,我需要到这个 python 文件所在的目录下写

Python代码

python colorU.py 

  或者写全 colorU.py 这个路径。都是很麻的事情,所以我需要把 colorU 加入环境变量中。我用的是 zsh,所以找到环境变量的配置文件:~/.zshrc,末尾加上配置:

Python代码

alias colorU="python ~/Documents/Development/PythonStudy/colorU.py"

  这个是经过另外以为同事指导后的最后可行版本,我最初的思路是把 colorU.py 文件设置成可执行文件,然后加入到 Path 当中。结果我把 colorU.py 这个文件的地址加入到了 Path 中,世界上PATH 应该是一个目录。这样添加别名的方式更方便。

也就是说如果我装客户端就可以不用我写的这个脚本了。但没关系我学习了 python,写了我自己的第一个真正有用的 python 代码。

  2. 一个bug:我是在写这篇文章的时候才发现这个 bug 的,类似0x33这样的字符串从后往前裁剪的时候写[-2:],当然没有问题,但是写0xf 这样的字符串就会有问题了。程序输入 5 5 5得到的结果是 #0x50x50x5。修改成[2:] 的裁剪就可以了。

倒向裁剪字符串引起的bug

  还可以继续升级体验:

  a. 直接在终端中输入 colorU 231 234 123 就可以得到结果 #e7ea7b;

  b. 配合Alfred, 呼出 Alfred 窗口后,输入色值,得到结果,回车直接复制十六进制到粘贴板。

  c. 保存之前已经转换过的色值,方便重复使用的颜色,直接复制十六进制颜色。

(0)

相关推荐

  • python 字符串split的用法分享

    比如我们的存储的格式的: 格式的: 姓名,年龄|另外一个用户姓名,年龄 name:haha,age:20|name:python,age:30|name:fef,age:55 那我们可以通过字符串对象的split方法切割字符串对象为列表. a = 'name:haha,age:20|name:python,age:30|name:fef,age:55' print a.split('|') 返回结果:['name:haha,age:20', 'name:python,age:30', 'name

  • Python中for循环详解

    与其它大多数语言一样,Python 也拥有 for 循环.你到现在还未曾看到它们的唯一原因就是,Python 在其它太多的方面表现出色,通常你不需要它们. 其它大多数语言没有像 Python 一样的强大的 list 数据类型,所以你需要亲自做很多事情,指定开始,结束和步长,来定义一定范围的整数或字符或其它可重复的实体.但是在 Python 中,for 循环简单地在一个列表上循环,与 list 解析的工作方式相同. 1. for  循环介绍 复制代码 代码如下: >>> li = ['a'

  • Python 字典(Dictionary)操作详解

    Python字典是另一种可变容器模型,且可存储任意类型对象,如字符串.数字.元组等其他容器模型.一.创建字典字典由键和对应值成对组成.字典也被称作关联数组或哈希表.基本语法如下: 复制代码 代码如下: dict = {'Alice': '2341', 'Beth': '9102', 'Cecil': '3258'} 也可如此创建字典: 复制代码 代码如下: dict1 = { 'abc': 456 };dict2 = { 'abc': 123, 98.6: 37 }; 注意:每个键与值用冒号隔开

  • Python科学计算环境推荐——Anaconda

    Anaconda是一个和Canopy类似的科学计算环境,但用起来更加方便.自带的包管理器conda也很强大. 首先是下载安装.Anaconda提供了Python2.7和Python3.4两个版本,同时如果需要其他版本,还可以通过conda来创建.安装完成后可以看到,Anaconda提供了Spyder,IPython和一个命令行.下面来看一下conda. 输入 conda list 来看一下所有安装时自带的Python扩展.粗略看了一下,其中包括了常用的 Numpy , Scipy , matpl

  • Python 字符串操作方法大全

    1.去空格及特殊符号 复制代码 代码如下: s.strip().lstrip().rstrip(',') 2.复制字符串 复制代码 代码如下: #strcpy(sStr1,sStr2)sStr1 = 'strcpy'sStr2 = sStr1sStr1 = 'strcpy2'print sStr2 3.连接字符串 复制代码 代码如下: #strcat(sStr1,sStr2)sStr1 = 'strcat'sStr2 = 'append'sStr1 += sStr2print sStr1 4.查

  • python中的字典详细介绍

    一.什么是字典? 字典是Python语言中唯一的映射类型. 映射类型对象里哈希值(键,key)和指向的对象(值,value)是一对多的的关系,通常被认为是可变的哈希表. 字典对象是可变的,它是一个容器类型,能存储任意个数的Python对象,其中也可包括其他容器类型. 字典类型与序列类型的区别: 1.存取和访问数据的方式不同. 2.序列类型只用数字类型的键(从序列的开始按数值顺序索引): 3.映射类型可以用其他对象类型作键(如:数字.字符串.元祖,一般用字符串作键),和序列类型的键不同,映射类型的

  • Python字符串的encode与decode研究心得乱码问题解决方法

    为什么会报错"UnicodeEncodeError: 'ascii' codec can't encode characters in position 0-1: ordinal not in range(128)"?本文就来研究一下这个问题. 字符串在Python内部的表示是unicode编码,因此,在做编码转换时,通常需要以unicode作为中间编码,即先将其他编码的字符串解码(decode)成unicode,再从unicode编码(encode)成另一种编码. decode的作用

  • python中执行shell命令的几个方法小结

    最近有个需求就是页面上执行shell命令,第一想到的就是os.system, 复制代码 代码如下: os.system('cat /proc/cpuinfo') 但是发现页面上打印的命令执行结果 0或者1,当然不满足需求了. 尝试第二种方案 os.popen() 复制代码 代码如下: output = os.popen('cat /proc/cpuinfo') print output.read() 通过 os.popen() 返回的是 file read 的对象,对其进行读取 read() 的

  • python操作日期和时间的方法

    不管何时何地,只要我们编程时遇到了跟时间有关的问题,都要想到 datetime 和 time 标准库模块,今天我们就用它内部的方法,详解python操作日期和时间的方法.1.将字符串的时间转换为时间戳 复制代码 代码如下: 方法:a = "2013-10-10 23:40:00"#将其转换为时间数组import timetimeArray = time.strptime(a, "%Y-%m-%d %H:%M:%S")#转换为时间戳:timeStamp = int(t

  • Python 元组(Tuple)操作详解

    一.创建元组 复制代码 代码如下: tup1 = ('physics', 'chemistry', 1997, 2000);tup2 = (1, 2, 3, 4, 5 );tup3 = "a", "b", "c", "d"; 创建空元组 复制代码 代码如下: tup1 = (); 元组中只包含一个元素时,需要在元素后面添加逗号来消除歧义 复制代码 代码如下: tup1 = (50,); 元组与字符串类似,下标索引从0开始,可以

随机推荐