- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在使用 Python 3.x 创建一个多语言“日历”小部件,该小部件具有用于年、月、日等的独立旋转框。要求是无论使用什么小部件,都绝不能隐藏 GUI 的任何部分时间,从而排除下拉列表等,使旋转框成为显而易见的选择。
如果有人知道在哪里可以找到纯 python/tkinter“日期和时间输入”widgit(理想地处理闰年和所有月末情况)的公共(public)域源代码,请指点我到那个存储库将不胜感激。
我能找到的最接近的解决方案是这个 OptionMenu 解决方案 (Change OptionMenu based on what is selected in another OptionMenu),但由于“不隐藏”的要求,它不能使用。以此为灵感(在查看 http://infohost.nmt.edu/tcc/help/pubs/tkinter/web/spinbox.html 上的 Spinbox 文档后)我想出了下面的代码。为了简单起见,我删除了处理闰年和月末问题的代码。除了两个问题外,该代码有效:
问题 1 – 我无法让“DaySpinBox”动态调整其范围以将其自身设置为“MonthSpinBox”中的月份:
根据我阅读 Mark Lutz 的“Python 编程”一书(第三版,第 383 和 384 页)的方式,我应该能够动态设置 DaySpinBox 的最大/最后一天(通过使用“values=”或“to= ”和“from_=”选项)以匹配出现在 MonthSpinBox 中的月份。我正在跟踪 MonthSpinBox 变量(“SelectedMonth”),并且根据书中的内容,我尝试使用这些方法更新 DaySpinBox:1 - 使用“to= SelectedMonth”。对此的一些尝试在创建 DaySpinBox 的调用中显示为注释。 (我是 lambda 的新手,也许我没有正确使用它们?),
2 - 使用“DaySpinBox[‘to’] = SelectedMonth”,以及3 - 使用“DaySpinBox.config( to = SelectedMonth )”。
我也尝试过在所有方法中使用“values=”但没有成功(首选“to=...”选项)。
问题 1:是否可以将 Spinbox 设置为使用动态范围,或者正如我开始怀疑的那样,它们的范围在创建 Spinbox 后是否无法更改?
问题 2:经过大量网络搜索后,我没有发现任何明确说明哪些 Spinbox 参数(“to=”、“from=”和“value=”关键字)可以动态更改而哪些不能动态更改的内容 – 哪里我可以找到此信息(适用于所有小部件类型)吗?
问题 2 – MonthSpinBox 总是初始化为一月而不是当前月份
我正在使用“textvariable”关键字将年、月和日旋转框初始化为“今天”。这适用于 YearSpinBox 和 DaySpinBox 但不适用于 MonthSpinBox。 (恼人的是,我认为 MonthSpinBox 正在工作,但我在尝试修复 DaySpinBox 时破坏了它)。唯一明显的区别是 Year 和 Day 旋转框使用整数,而 Month 旋转框使用字符串。有什么建议吗?
对于这两个问题,我都考虑了 LEGB 问题的可能性,但没有嵌套函数,因此变量隐藏应该不是问题 - 除非我的变量之一正在复制和隐藏在 tkinter 等中定义的变量。
我错过了什么?
顺便说一句,我知道使用全局变量的优缺点,也知道 PEP8 ( http://www.python.org/dev/peps/pep-0008/ ) - 请参阅目录中的第二个项目符号。 ;>)
谢谢。
from tkinter import *
from tkinter import ttk
from datetime import datetime
from collections import OrderedDict
root = Tk() # put here so IntVar (etc.) is useable during initialization
StartUpDateTime = datetime.now()
DefaultYear = StartUpDateTime.year
DefaultMonthNumber = StartUpDateTime.month
DefaultDayOfMonth = StartUpDateTime.day
# These are only used to build the Month name & length dictionary
YearAndMonthLengths = [ 365, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31 ]
EnglishMonthNames = ( 'Entire Year', 'January', 'February', 'March',
'April', 'May', 'June', 'July', 'August', 'September',
'October', 'November', 'December' )
FrenchMonthNames = ( 'année entière', 'janvier', 'février', 'mars',
'avril', 'mai', 'juin', 'juillet', 'août', 'septembre',
'octobre', 'novembre', 'décembre' )
#SpanishMonthNames = ....
#ItalianMonthNames = ....
Month_Names = FrenchMonthNames
Month_Names = EnglishMonthNames # comment out this line to use French
# Create dictionary containing month names that appear in the Month spinbox.
# OrderedDict used because Month name (=key) field must be language-independent.
DaysInMonth = OrderedDict()
for i in range( 0, len( Month_Names ) ) :
DaysInMonth[ Month_Names[ i ] ] = YearAndMonthLengths[ i ]
DefaultMonthName = Month_Names[ DefaultMonthNumber ]
DefaultMonthLength = DaysInMonth[ DefaultMonthName ]
# Initialize the Spinbox interface variables to todays date
SelectedYear = IntVar( value = DefaultYear )
SelectedMonthName = StringVar( value = DefaultMonthName )
SelectedMonthLength = IntVar( value = DefaultMonthLength )
SelectedDay = IntVar( value = DefaultDayOfMonth )
#-------------------------------------------------------------------------------
def GetChosenMonthLength( *args ) :
global SelectedMonthLength
SelectedMonthLength.set( DaysInMonth[ SelectedMonthName.get() ] )
return
#-------------------------------------------------------------------------------
mainframe = Frame( root )
mainframe.grid( row = 0, column = 0 )
# Show today's date. If it's July 17th, 2023 the spinboxes must be initialized
# to "July" ("julliet" if using French), "17" and "2023".
YearSpinBox = Spinbox( mainframe,
from_ = 2000, to = 2050,
textvariable = SelectedYear,
wrap = TRUE, state = 'readonly', width = 5 )
MonthSpinBox = Spinbox( mainframe,
values = tuple( DaysInMonth.keys() )[1:],
textvariable = SelectedMonthName,
wrap = TRUE, state = 'readonly', width = 10 )
DaySpinBox = Spinbox( mainframe,
from_ = 1,
to = SelectedMonthLength.get(),
# to = DaysInMonth[ SelectedMonthName.get() ],
# values = tuple( str( i ) for i in range( 1, SelectedMonthLength.get() + 1 ) ),
# values = lambda : tuple( str( i ) for i in range( 1, DaysInMonth[ SelectedMonthName.get() ] + 1 ) )
textvariable = SelectedDay,
wrap = TRUE, state = 'readonly', width = 16
)
MonthSpinBox.grid( row = 0, column = 0 )
DaySpinBox.grid( row = 0, column = 1 )
YearSpinBox.grid( row = 0, column = 2 )
SelectedMonthName.trace( 'w', GetChosenMonthLength )
mainloop()
顺便说一句,示例代码省略了证明所有 Spinbox 接口(interface)变量都被正确更新的调试代码 - 包括包含更改/新月份的最后一天的变量(使用“发送”到 Day Spinbox TO=”关键字)。
最佳答案
所有小部件的所有选项始终可以动态配置。如果我没记错的话,只有一个异常(exception),这是一个几乎没有人使用过的功能:框架上的 class
选项。
与更新日期旋转框相关,我没有看到您尝试更新它的位置,所以我不确定您认为它应该更新的原因。要更新旋转框,请将命令附加到月份旋转框,然后在回调中进行更新。
例如:
def update_days():
maxdays = int(DaysInMonth[SelectedMonthName.get()])
DaySpinBox.config(to=maxdays)
MonthSpinBox = Spinbox(...,command=update_days)
至于为什么月份没有设置为当前月份……我就不知道了。看起来你做的事情是对的。这个和其他小部件之间的唯一区别是这是一个 StringVar 而不是 IntVar,并且月份旋转框有一个 values
参数。也许这是由这种差异触发的 tkinter 中的错误或记录不完整的功能。
一个简单的解决方法是在创建月份旋转框后添加 SelectedMonthName.set(DefaultMonthName)
以将 stringvar 重置为正确的默认值。
关于python - 动态设置 tkinter Spinbox 的范围,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20528596/
我不能解决这个问题。和标题说的差不多…… 如果其他两个范围/列中有“否”,我如何获得范围或列的平均值? 换句话说,我想计算 A 列的平均值,并且我有两列询问是/否问题(B 列和 C 列)。我只希望 B
我知道 python 2to3 将所有 xrange 更改为 range 我没有发现任何问题。我的问题是关于它如何将 range(...) 更改为 list(range(...)) :它是愚蠢的,只是
我有一个 Primefaces JSF 项目,并且我的 Bean 注释有以下内容: @Named("reportTabBean") @SessionScoped public class Report
在 rails3 中,我在模型中制作了相同的范围。例如 class Common ?" , at) } end 我想将公共(public)范围拆分为 lib 中的模块。所以我试试这个。 module
我需要在另一个 View 范围 bean 中使用保存在 View 范围 bean 中的一些数据。 @ManagedBean @ViewScoped public class Attivita impl
为什么下面的代码输出4?谁能给我推荐一篇好文章来深入学习 javascript 范围。 这段代码返回4,但我不明白为什么? (function f(){ return f(); functio
我有一个与此结构类似的脚本 $(function(){ var someVariable; function doSomething(){ //here } $('#som
我刚刚开始学习 Jquery,但这些示例对我帮助不大...... 现在,以下代码发生的情况是,我有 4 个表单,我使用每个表单的链接在它们之间进行切换。但我不知道如何在第一个函数中获取变量“postO
为什么当我这样做时: function Dog(){ this.firstName = 'scrappy'; } Dog.firstName 未定义? 但是我可以这样做: Dog.firstNa
我想打印文本文件 text.txt 的选定部分,其中包含: tickme 1.1(no.3) lesson1-bases lesson2-advancedfurther para:using the
我正在编写一些 JavaScript 代码。我对这个关键字有点困惑。如何在 dataReceivedHandler 函数中访问 logger 变量? MyClass: { logger: nu
我有这个代码: Public Sub test() Dim Tgt As Range Set Tgt = Range("A1") End Sub 我想更改当前为“A1”的 Tgt 的引
我正忙于此工作,以为我会把它放在我们那里。 该数字必须是最多3个单位和最多5个小数位的数字,等等。 有效的 999.99999 99.9 9 0.99999 0 无效的 -0.1 999.123456
覆盖代码时: @Override public void open(ExecutionContext executionContext) { super.open(executio
我想使用 preg_match 来匹配数字 1 - 21。我如何使用 preg_match 来做到这一点?如果数字大于 21,我不想匹配任何东西。 example preg_match('([0-9]
根据docs range函数有四种形式: (range) 0 - 无穷大 (range end) 0 - 结束 (range start end)开始 - 结束 (range start end st
我知道有一个UISlider,但是有人已经制作了RangeSlider(用两个拇指吗?)或者知道如何扩展 uislider? 最佳答案 我认为你不能直接扩展 UISlider,你可能需要扩展 UICo
我正在尝试将范围转换为列表。 nums = [] for x in range (9000, 9004): nums.append(x) print nums 输出 [9000] [9
请注意:此问题是由于在运行我的修饰方法时使用了GraphQL解析器。这意味着this的范围为undefined。但是,该问题的基础知识对于装饰者遇到问题的任何人都是有用的。 这是我想使用的基本装饰器(
我正在尝试创建一个工具来从网页上抓取信息(是的,我有权限)。 到目前为止,我一直在使用 Node.js 结合 requests 和 Cheerio 来拉取页面,然后根据 CSS 选择器查找信息。我已经
我是一名优秀的程序员,十分优秀!