我有.txt
,如下所示:
MasterCard
R$ 66,12
Hipercard
R$ 7.501,98
MasterCard
R$ 48,19
Hipercard
R$ 7.742,46
MasterCard
R$ 48,19
Hipercard
R$ 5.846,14
MasterCard
R$ 48,19
Hipercard
R$ 4.210,65
Visa
R$ 4.210,65
MasterCard
R$ 48,19
Hipercard
R$ 2.892,20
MasterCard
R$ 48,19
Visa
R$ 4.210,65
Hipercard
R$ 1.944,19
Hipercard
R$ 584,04
Visa
R$ 4.210,65
我需要一个.bat
文件(可以在PowerShell中)按照描述和值组织行,如下所示:
-----------------
MasterCard
R$ 66,12
MasterCard
R$ 48,19
MasterCard
R$ 48,19
MasterCard
R$ 48,19
MasterCard
R$ 48,19
MasterCard
R$ 48,19
----------------
Hipercard
R$ 7.501,98
Hipercard
R$ 7.742,46
Hipercard
R$ 5.846,14
Hipercard
R$ 4.210,65
Hipercard
R$ 2.892,20
Hipercard
R$ 1.944,19
Hipercard
R$ 584,04
--------------
Visa
R$ 4.210,65
Visa
R$ 4.210,65
Visa
R$ 4.210,65
使用.bat
文件可以做到吗?我陷入了如何开始。
我正在尝试使用一个简单的命令:sort test.txt /o testout.txt
但它不起作用。
我有另一个想法。运行此命令我可以将所有行放在同一行:
for /f "usebackq tokens=* delims=" %%a in ("frt01.txt") do (echo(%%a)>>test.txt
for /f "usebackqdelims=" %%i in ("test.txt") do @<nul set /p"=%%i ">>"test2.txt"
del test.txt /S /Q /
现在,描述和值只在一行中:
MasterCard R$ 66,12 Hipercard R$ 7.501,98 MasterCard R$ 48,19 Hipercard R$ 7.742,46 MasterCard R$ 48,19 Hipercard R$ 5.846,14 MasterCard R$ 48,19 Hipercard R$ 4.210,65 MasterCard R$ 48,19 Hipercard R$ 2.892,20 MasterCard R$ 48,19 Hipercard R$ 1.944,19 Hipercard R$ 584,04
我怎么能这样做呢? (在每个值后键入'enter')
MasterCard R$ 66,12
Hipercard R$ 7.501,98
MasterCard R$ 48,19
Hipercard R$ 7.742,46
MasterCard R$ 48,19
Hipercard R$ 5.846,14
MasterCard R$ 48,19
Hipercard R$ 4.210,65
MasterCard R$ 48,19
Hipercard R$ 2.892,20
MasterCard R$ 48,19
Hipercard R$ 1.944,19
Hipercard R$ 584,04
因为我可以使用此命令排序:sort test2.txt /o output.txt
我想这样做更容易。
@michael_heath这就是我在说的话:
Hipercard R$ 584,04
Hipercard R$ 1.944,19
Hipercard R$ 2.892,20
Hipercard R$ 4.210,65
Hipercard R$ 5.846,14
Hipercard R$ 7.501,98
Hipercard R$ 7.742,46
------------------------
MasterCard R$ 48,19
MasterCard R$ 48,19
MasterCard R$ 48,19
MasterCard R$ 48,19
MasterCard R$ 48,19
MasterCard R$ 66,12
------------------------
Visa R$ 48,19
Visa R$ 48,19
Visa R$ 48,19
------------------------
答案 0 :(得分:4)
在对数据进行排序之前,您需要解析它。您可以将ConvertFrom-String
cmdlet与模板一起使用来执行此操作:
$Template = @'
{CardProvider*:MasterCard}
R$ {Amount:66,12}
{CardProvider*:Hipercard}
R$ {Amount:7.501,98}
{CardProvider*:Visa}
R$ {Amount:4.210,65}
'@
$Transactions = Get-Content path\to\file.txt |ConvertFrom-String -TemplateContent $Template
$Transactions
变量现在将包含一个对象数组,每个对象都具有CardProvider
和Amount
属性。要按提供商排序,然后按金额排序,我们可以执行以下操作:
# Define output file name
$OutputFile = 'output.txt'
# Group by card type first
$Transactions |Group-Object CardProvider |ForEach-Object {
# Write seperator to output file:
'----------------' |Add-Content -Path $OutputFile
# Now we sort each group of cards by descending amount
$_.Group |Sort-Object {$_.Amount -replace '\.' -replace ',','.' -as [decimal]} -Descending |ForEach-Object {
# Finally write the contents to file again
$_.CardProvider,"R$ $($_.Amount)","" |Add-Content -Path $OutputFile
}
}
答案 1 :(得分:3)
所有批处理文件代码
选项1
@echo off
setlocal enabledelayedexpansion
(
for /f "tokens=1,2" %%A in (frt01.txt) do (
if not "%%~A" == "R$" (
set "card=%%~A "
set "card=!card:~,11!"
) else (
set "value= %%~B"
set "value=!value:~-9!"
echo !card! %%~A !value!
)
)
) > unsorted.txt
sort unsorted.txt /o output.txt
rem Optional code below to insert ------- between rows after sort.
set "last_card="
(
for /f "delims=" %%A in (output.txt) do (
for /f %%B in ("%%~A") do set "card=%%~B"
if defined last_card if not "!card!" == "!last_card!" (
echo ------------------------
)
echo %%A
set "last_card=!card!"
)
echo ------------------------
) > tmp.txt
move /y tmp.txt output.txt
这是延迟扩张的概念。固定间距是
使用sort
可以更好地订购不同长度
的卡和货币价值。
for /?
用于令牌描述等。set /?
使用替换语法,即set "card=!card:~,11!"
。选项2
@(
@echo off
setlocal enabledelayedexpansion
for /f "tokens=1,2" %%A in (frt01.txt) do (
if not "%%~A" == "R$" (
set "card=%%~A "
call set "card=%%card:~,11%%"
) else (
set "value= %%~B"
call set "value=%%value:~-9%%"
call echo "%%card%%" "%%A" "%%value%%"
)
)
) | sort /o output.txt
这是一个不寻常的概念。像以前的代码一样,使用固定
间距。它不使用临时文件,因为它直接管道
sort
。
即使没有setlocal enabledelayedexpansion
,也会使用!
使用。延迟变量不会扩展。如果没有,
延迟扩展,call set
和call echo
会
不行。
可以在Win7上运行,但也许它的奇怪行为可能 使其他代码成为更好的选择。
选项3
@echo off
setlocal
if not "%~1" == "" (
if "%~1" == "/?" goto :help
for %%A in (%*) do call :read "%%~A"
exit /b
)
rem If no arguments, do this optional task instead.
> "%~dp0unsorted.txt" call :read "frt01.txt"
sort "%~dp0unsorted.txt" /o "%~dp0output.txt"
del "%~dp0unsorted.txt"
exit /b
:read
setlocal enabledelayedexpansion
for /f "usebackq tokens=1,2" %%A in ("%~1") do (
if not "%%~A" == "R$" (
set "card=%%~A "
set "card=!card:~,11!"
) else (
set "value= %%~B"
set "value=!value:~-9!"
echo !card! %%~A !value!
)
)
exit /b
:help
echo Prints Hipercard, MasterCard... vertical list as 3 horizontal fixed columns.
echo If multiple files are passed as arguments, they will be printed in sequence.
echo.
echo Syntax: %~nx0 file [file [file]]
echo.
echo Examples:
echo %~nx0 "test 1.txt"
echo %~nx0 test1.txt test2.text ^| sort /o output.txt
exit /b
这是rem
下方的独立脚本或运行代码
评论行。您可以删除可选代码和位置
PATH中的脚本,因此您可以从控制台运行它
任何地方。
如果脚本名为cardsorter.cmd,那么你就可以了。
cardsorter frt01.txt | sort /o output.txt
在命令提示符下。
所有选项的输出
Hipercard R$ 584,04
Hipercard R$ 1.944,19
Hipercard R$ 2.892,20
Hipercard R$ 4.210,65
Hipercard R$ 5.846,14
Hipercard R$ 7.501,98
Hipercard R$ 7.742,46
MasterCard R$ 48,19
MasterCard R$ 48,19
MasterCard R$ 48,19
MasterCard R$ 48,19
MasterCard R$ 48,19
MasterCard R$ 66,12
Visa R$ 4.210,65
Visa R$ 4.210,65
Visa R$ 4.210,65
注意强>
选项1将--------------
插入到单独的卡类型中。
答案 2 :(得分:1)
这是一个批处理文件解决方案。要将线堆叠在一起,只需使用变量来保存上一行。
@echo off
setlocal enabledelayedexpansion
set "line1="
(FOR /F "delims=" %%G IN (input.txt) DO (
IF NOT DEFINED line1 (
set "line1=%%G
) else (
echo !line1! %%G
set "line1="
)
))>temp.txt
sort temp.txt>output.txt
答案 3 :(得分:1)
以下代码将输入文件解析为事务对象数组,对它们进行排序,然后输出已排序的数组。并不是说金额被排序为右对齐字符串。
$unsortedtransactions = @()
Get-Content .\in.txt -ReadCount 3 |
ForEach-Object {
$Matches = $null
"$_" -match '([^\s]*)\s*(\S*)\s*(.*)$(.*)$' | Out-Null
$thisrecord = [PSCustomObject] @{ Card = $Matches[1]
Currency = $Matches[2]
Amount = $("{0,15}" -f @($Matches[3].Trim()))
}
$unsortedtransactions += $thisrecord
}
$sortedtransactions = $unsortedtransactions | Sort-Object -Property Card, Currency, Amount
foreach ($t in $sortedtransactions) {
$("{0}`r`n{1} {2}`r`n" -f @($t.Card, $t.Currency, $t.Amount.Trim())) |
Out-File -FilePath st.txt -Encoding ascii -Append
}