- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我必须在 python 中编写一个以前用 Java 编写的库。来自 Java 背景的 python 给我带来了一些困难。我坚持选择正确的pythonic做事方式..
所以,我的java代码是这样的:
import java.util.Collection;
public abstract class MyEnumBaseClass
{
protected int value;
protected String description = null;
protected MyEnumBaseClass(int iValue, String iDescription)
{
value = iValue;
description = iDescription;
}
public int getValue()
{
return value;
}
public String getDescription()
{
return description;
}
protected static MyEnumBaseClass getEnum(Collection<MyEnumBaseClass> iter, int value)
{
for (MyEnumBaseClass enumObj : iter)
{
if (enumObj.getValue() == value)
{
return enumObj;
}
}
return null;
}
}
import java.util.ArrayList;
import java.util.Collection;
public class MyEnumClass extends MyEnumBaseClass
{
private final static Collection<MyEnumBaseClass> enumList = new ArrayList<MyEnumBaseClass>();
public final static int ERROR1 = 1;
public final static int ERROR2 = 2;
public final static int ERROR3 = 3;
public final static int ERROR4 = 4;
public final static MyEnumClass ErrorEnum1 = new MyEnumClass(ERROR1, "ERROR1");
public final static MyEnumClass ErrorEnum2 = new MyEnumClass(ERROR2, "ERROR1");
public final static MyEnumClass ErrorEnum3 = new MyEnumClass(ERROR3, "ERROR1");
public final static MyEnumClass ErrorEnum4 = new MyEnumClass(ERROR4, "ERROR1");
protected MyEnumClass(int iValue, String iDescription)
{
super(iValue, iDescription);
}
public static int getCount()
{
return enumList.size();
}
public static Collection<MyEnumBaseClass> getList()
{
return enumList;
}
public static MyEnumBaseClass getEnum(int value)
{
return getEnum(enumList, value);
}
}
# MODULE MYENUMBASECLASS:::
class MyEnumBaseClass(object):
def __init__(self, iValue, iDescription, ui = None):
self._value = iValue
self._description = iDescription
def getValue(self):
return self._value
def getDescription(self):
return self._description
@classmethod
def getEnum(cls, value, itr):
for enumObj in itr:
if enumObj.getValue() == value:
return enumObj
return None
# MODULE: ENUMS:::
from MyEnumBaseClass import MyEnumBaseClass
__all__ = ["MyEnumClassConstants", "MyEnumClass", "MyEnums"]
_enumList = []
class MyEnumClassConstants(object):
ERROR1 = 1
ERROR2 = 2
ERROR3 = 3
ERROR4 = 4
class MyEnumClass(MyEnumBaseClass):
def __init__(self, v, d, ui):
global _enumList
super(MyEnumClass, self).__init__(v, d, ui)
_enumList.append(self)
@staticmethod
def getCount():
return len(_enumList)
@staticmethod
def getList():
return _enumList
@classmethod
def getEmum(cls, value, itr = None):
return super(MyEnumClass, cls).getEnum(value, _enumList)
class MyEnums(object):
ErrorEnum1 = MyEnumClass(MyEnumClassConstants.ERROR1, "ERROR1");
ErrorEnum2 = MyEnumClass(MyEnumClassConstants.ERROR2, "ERROR2");
ErrorEnum3 = MyEnumClass(MyEnumClassConstants.ERROR3, "ERROR3");
ErrorEnum4 = MyEnumClass(MyEnumClassConstants.ERROR4, "ERROR4");
最佳答案
好吧,我想你知道你的代码不是最优的,当然是 不是 要走的路。另一个问题是我们不能说你怎么能“用python写一些东西给我Java代码提供的功能”,因为我们不知道你到底想做什么。也就是说,您的代码中有很多明显的 Java 偏见,可以毫无问题地删除:
MyEnumBaseClass
和 MyEnumClass
?你只能拥有一个。它将减少类的数量和模块的数量。即使您想扩展您的枚举,您也会看到,在简化代码之后,您的 MyEnumClass
将非常简单,您可以毫无问题地扩展它。 class MyEnumClass(object):
def __init__(self, value, description, ui = None):
self.value = value
self.description = description
MyEnumClassConstants
和 MyEnums
.只需在模块级别创建一些变量。让我们在下面的项目之后看看如何做到这一点。 getEnum()
上课方法?这可能只是一个函数,您不必担心冲突,因为它位于模块内部:def getEnum(value, itr):
for enumObj in itr:
if enumObj.value == value:
return enumObj
return None
(
ERROR1,
ERROR2,
ERROR3,
ERROR4
) = range(1, 5)
_enums = (
ErrorEnum1,
ErrorEnum2,
ErrorEnum3,
ErrorEnum4
) = (
MyEnumClass(ERROR1, "ERROR1"),
MyEnumClass(ERROR2, "ERROR2"),
MyEnumClass(ERROR3, "ERROR3"),
MyEnumClass(ERROR4, "ERROR4")
)
_enums
作为模块的公共(public)成员,但让我们轻松处理您的 Java-itis :P 正如我们对 getEnum()
所做的那样,让我们处理其他类方法:将它们声明为模块中的函数:def getCount():
return len(_enums)
def getList():
return _enums
getEnum()
通过更改默认参数:def getEnum(value, itr=_enums):
for enumObj in itr:
if enumObj.value == value:
return enumObj
return None
__all__
在这里声明。唯一不属于界面一部分的是_enums
。元组,它前面是 _
其中,根据PEP-8 , 表示它不应该在外部使用。但让我们说它会留下来。你的模块有一个新的接口(interface),有更多的常量和函数:__all__ = ["MyEnumClass", "ERROR1", "ERROR2", "ERROR3", "ERROR4",
"ErrorEnum1", "ErrorEnum2", "ErrorEnum3", "ErrorEnum4",
"getCount", "getList", "getEnum"]
MyEnumClass
从界面,但好吧,你可能想使用它,所以我会离开它。请注意,__all__
value 不会避免访问模块的另一个组件。它只是更改了文档 __all__ = ["MyEnumClass", "ERROR1", "ERROR2", "ERROR3", "ERROR4",
"ErrorEnum1", "ErrorEnum2", "ErrorEnum3", "ErrorEnum4",
"getCount", "getList", "getEnum"]
class MyEnumClass(object):
def __init__(self, value, description, ui = None):
self.value = value
self.description = description
(
ERROR1,
ERROR2,
ERROR3,
ERROR4
) = range(1, 5)
_enums = (
ErrorEnum1,
ErrorEnum2,
ErrorEnum3,
ErrorEnum4
) = (
MyEnumClass(ERROR1, "ERROR1"),
MyEnumClass(ERROR2, "ERROR2"),
MyEnumClass(ERROR3, "ERROR3"),
MyEnumClass(ERROR4, "ERROR4")
)
def getCount():
return len(_enums)
def getList():
return _enums
def getEnum(value, itr=_enums):
for enumObj in itr:
if enumObj.value == value:
return enumObj
return None
ERROR1
,
ERROR2
等变量 - 没有类,没有函数,只有变量中的值。实际上,即使创建错误代码的想法似乎也不合适:您应该更喜欢创建异常,因为正如 Python 之禅所说,
errors should never pass silently (或者,正如 Eric Raymond 的 Unix 哲学所说,
when you must fail, fail noisily and as soon as possible)。尽管如此,我敢打赌,我所做的更改可以让您对编写 Python 有更准确的了解。
关于java - 在 Python 中重写 Java 代码的 Pythonic 方式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11215682/
我习惯于使用 Apache 服务器,所以当启用 mod_rewrite 时,我可以创建一个 htaccess 文件并使用 URL 重写。 这是我的 htaccess 文件: RewriteEngine
我正在尝试编写一个 mixin 来修改输出的父选择器。这个想法是,在调用 mixin 的情况下,父选择器需要对其进行字符串替换。我有大部分工作,但我不知道如何吞下 & . .test { @inc
我有一个本地目录(上传)和一个 S3 桶设置。 当用户上传图片时,文件存储在本地目录:/uploads/member_id/image_name30 分钟后,系统将文件上传到 S3 使用相同的路径:s
我正在尝试使用以下内容重写代理页面的正文链接: sub_filter http://proxied.page.come http://local.page.com; sub_filte
关闭。这个问题需要更多focused .它目前不接受答案。 想改善这个问题吗?更新问题,使其仅关注一个问题 editing this post . 1年前关闭。 Improve this questi
我尝试在我的 JSF 应用程序中使用“重写”(http://ocpsoft.org/rewrite/)。 一切都很好,我已经创建了规则: .addRule(Join.path("/profile/{p
我可以在 AEM 中大致看到两种 URL 重写方法: /etc/map/http(s)下的Sling映射(sling:Mapping) 使用链接重写器/TransformerFactory 重写 UR
我有一个 onclick 函数,我想将 anchor 添加到 href 值。我不想更改 URL,因为我需要该网站仍然可以为没有 javascript 的人/出于 SEO 目的而运行。所以这是我尝试使用
我必须在 UILabel 中显示货币和价格。在一个标签中,但使用不同的字体大小。现在看起来像这样: ...我这样做是重写drawTextInRect:,如下所示: - (void)drawTextIn
我正在尝试使用以下内容进行重定向: RewriteRule ^reviews/area/Santa-Barbara%2F$"/reviews/area/santa-barbara" [R=301,NC
我使用 FOSUserBundle 并且我想覆盖他的 registerAction Controller 。我阅读了与覆盖 FOSUserBundle Controller 相关的文档,但它不起作用。
我正在尝试让 URL 重写在我的网站上运行。这是我的 .htaccess 的内容: RewriteEngine On RewriteRule ^blog/?$ index.php?page=blog
好吧,这让我发疯了......我正在尝试像这样重写我的网址: Now: http://www.somedomain.com/Somepage.aspx http://www.somedomain.co
final方法不能在子类中重写。但凭借 Scala 的魔力,这似乎是可能的。 考虑以下示例: trait Test { final def doIt(s: String): String = s
我有一个类似下面的查询: Select ser.key From dbo.Enrlmt ser Where ser.wd >= @FromDate AND ser.wd ser.wd
我是 nginx 的新手,只是想做一些我认为应该很简单的事情。如果我这样做:- curl http://localhost:8008/12345678 我希望返回 index.html 页面。但是我得
我们的一位客户创建了一个二维码,其中 url 中包含一个空格。 我将如何编写处理此问题的 nginx 重定向? 在字符串中使用诸如“%20”之类的东西的几次尝试似乎会导致 nginx 出错或使 con
我正在尝试覆盖 appendChild 方法,以便我可以控制动态创建的元素并在插入页面之前根据需要修改它们。我尝试了这个示例代码,只是为了看看它是否可以完成: var f = Element.prot
我目前正在使用以下功能,当用户单击某处以确定是否隐藏下拉菜单(在 react 中)。一切正常,但当我单击正文时,它会记录以下内容。 我尝试重写它几次,但我找不到解决这个问题的方法。 Uncaught
我正在开发一个 Spring Integration/Boot 应用程序。我使用多文档 application.yml (src/main/resources/application.yml) 来设置
我是一名优秀的程序员,十分优秀!