Tenho uma solução de aplicativo web no Visual Studio 2022 que sempre leva pelo menos 5 minutos para ser compilada e preciso de uma maneira de acelerar isso. Na solução, tenho um projeto de dados que inclui minhas migrações do EF Core, e meu palpite é que o número de migrações (quase 1.000 neste momento) é o que está causando a lentidão nas compilações. Existe uma maneira fácil de excluir o namespace "migrations" de uma ação de compilação? Ou há algo mais que eu possa fazer com as migrações para mitigar o impacto delas nos tempos de compilação?
Suponha que eu tenha o seguinte XML:
<?xml version="1.0" encoding="utf8"?>
<test>
<list>
<li>a</li>
<li>a</li>
<li begin="true">b</li> <!-- begin of the "b" list -->
<li>b</li>
<li>b</li>
<li end="true">b</li> <!-- end of the "b" list -->
<li>c</li>
<li>c</li>
</list>
</test>
e eu queria dividir essa lista em três listas com base nos atributos begin
e end
usando XSLT 1.0, de modo que o resultado seja:
<list>
<li>a</li>
<li>a</li>
</list>
<list>
<li>b</li>
<li>b</li>
<li>b</li>
<li>b</li>
</list>
<list>
<li>c</li>
<li>c</li>
</list>
Consegui selecionar a primeira e a terceira lista, mas tive dificuldade em corresponder ao intervalo da lista do meio:
<xsl:template match="list">
<list>
<xsl:apply-templates select="li[@begin = 'true']/preceding-sibling::li" />
</list>
<list>
<xsl:apply-templates select="li[...]" /> <!-- Hmm 🤔 -->
</list>
<list>
<xsl:apply-templates select="li[@end = 'true']/following-sibling::li" />
</list>
</xsl:template>
Tentei várias expressões usando position()
and count()
mas não consegui acertar.
Adendo: os atributos begin
e end
são únicos, ou seja, há exatamente um grupo desse tipo na lista original.
Estou tentando criar um arquivo oculto no Windows usando Python, mas depois de ocultá-lo, fica impossível escrever. No entanto, ler este arquivo é possível.
import ctypes
with open("test.txt", "r") as f: print('test')
ctypes.windll.kernel32.SetFileAttributesW("test.txt", 0x02) # adding h (hidden) attribute to a file
with open("test.txt", "r") as f: print('test') # works
with open("test.txt", "w") as f: print('test') # error
Erro:
Traceback (most recent call last):
File "C:\Users\user\Documents\client\test.py", line 8, in <module>
with open("test.txt", "w") as f: print('test') # error
PermissionError: [Errno 13] Permission denied: 'test.txt'
Usar 0x22
(que é a
atributo e h
atributo) em vez de 0x02
não ajuda. O mesmo erro ocorre. Depois de tornar o arquivo visível novamente via , attrib -H test.txt
torna-se possível abri-lo em modo de gravação. No entanto, até onde eu sei, arquivos ocultos devem ser graváveis no Windows.
SO: Windows 11
Versão do Python: Python 3.10.2
Quero desenhar uma imagem sobreposta a um painel desfocado com texto. O problema é que a moldura do painel depende da moldura do texto. Ao mesmo tempo, mask
o modificador de tempo é definido separadamente do texto e do painel.
Meu código:
struct SomeView: View {
@State var frame: CGRect = .zero
var body: some View {
ZStack {
Image(.defaultCard)
Image(.defaultCard)
.blur(radius: 30)
.mask {
Rectangle()
.frame(width: frame.width, height: frame.height)
.position(x: frame.midX, y: frame.midY)
}
ZStack(alignment: .bottomLeading) {
Color.clear
HStack {
Text("...")
Text("...")
}
.padding()
.background {
GeometryReader { geometry in
Color.clear
.onAppear {
frame = geometry.frame(in: .global)
}
.onChange(of: geometry.size) { _ in
frame = geometry.frame(in: .global)
}
}
}
}
.frame(maxWidth: .infinity, maxHeight: .infinity)
}
}
}
Tudo está desenhado, mas a posição da máscara está incorreta. O código a seguir retorna um quadro incorreto:
frame = geometry.frame(in: .global)
Como resolver esse problema? Entendo que eu poderia usar o desfoque do UIKit, mas o desfoque do SwiftUI atende melhor às minhas necessidades.
Console.writer().println() está exibindo "Digite 3 palavras" após console.readLine(). Alguém pode explicar o porquê?
class Class3{
public static void main(String... args){
Console console = System.console();
if(console == null){
throw new RuntimeException("No console");
}else{
//System.out.println("Enter 3 words");
//console.format("Enter 3 words");
console.writer().println("Enter 3 words");
List<String> strings = new ArrayList<>();
for(int i=0;i<3;++i){
strings.add(console.readLine());
}
console.format("You entered %s, %s, %s",
strings.get(0),
strings.get(1),
strings.get(2)
);
console.writer().println();
}
}
}
Saída: Saída da aplicação
Tentei usar System.out.println() e console.format() e ambos imprimem "Digite 3 palavras" antes que o aplicativo aceite 3 strings
Eu gostaria de fazer algo como
select tc.owner, tc.table_name, tc.column_name, tc.data_type, tc.data_length
from all_tab_cols tc
inner join all_tables t on tc.owner = t.owner and tc.table_name = t.table_name
where tc.owner = 'LEMANS'
AND tc.data_type LIKE '%VARCHAR%'
ALTER TABLE tc.table_name MODIFY tc.column_name VARCHAR2(tc.data_length CHAR);
Como posso fazer isso funcionar? Quero alterar a tabela em todas as linhas selecionadas.
Registrei o aplicativo no Azure e tenho seu clientId e clientSecret para autenticação.
Quero poder usar o PowerShell para gravar em uma célula de arquivo do Excel Online. O registro do aplicativo deve ter permissão de API suficiente (Files.Read.All, Files.ReadWrite.All, Sites.Manage.All, Sites.Read.All, Sites.ReadWrite.All e consentimento do administrador) para gravar em um arquivo do Excel Online armazenado no canal do Teams, e deve ter permissão de edição nas próprias configurações do arquivo.
No PowerShell, consigo obter um arquivo do Excel online e obter o valor de uma célula, mas não consigo escrever na célula porque, quando tento fazer a parte de escrita, recebo este erro: Invoke-RestMethod: O servidor remoto retornou um erro: (400) Solicitação inválida.
para esta linha:
$response = Invoke-RestMethod -Method Patch -Uri "https://graph.microsoft.com/v1.0/drives/$driveId/items/$fileId/workbook/worksheets/$sheetName/range(address='B1')" -Headers @{ Authorization = "Bearer $accessToken" } -Body ($updateBody | ConvertTo-Json) -ContentType "application/json"
Alguém pode me ajudar como fazer a escrita em uma célula de arquivo do Excel Online?
Aqui está o script completo do Powershell:
# --- Configuration ---
$tenantId = "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"
$clientId = "yyyyyyyy-yyyy-yyyy-yyyy-yyyyyyyyyyyy"
$clientSecret = "qqqqq~qqqqqqqqqqqqqqqq.qqqqq_qqqqqqqqqqq"
$teamId = "zzzzzzzz-zz15-4zzz-9zzz-eazzzzzzzzzz" # Extracted from the team link
$channelId = "19:[email protected]" # Extracted from the channel link
$excelFileName = "Information_Point.xlsx"
$worksheetName = "NewHireLog"
# Get Access Token
$body = @{
grant_type = "client_credentials"
client_id = $clientId
client_secret = $clientSecret
resource = "https://graph.microsoft.com"
}
$response = Invoke-RestMethod -Method Post -Uri "https://login.microsoftonline.com/$tenantId/oauth2/token" -ContentType "application/x-www-form-urlencoded" -Body $body
$accessToken = $response.access_token
# Get Files Folder ID
$response = Invoke-RestMethod -Method Get -Uri "https://graph.microsoft.com/v1.0/teams/$teamId/channels/$channelId/filesFolder" -
Headers @{ Authorization = "Bearer $accessToken" }
$driveId = $response.parentReference.driveId
$folderId = $response.id
# List Files in the Folder
$response = Invoke-RestMethod -Method Get -Uri "https://graph.microsoft.com/v1.0/drives/$driveId/items/$folderId/children" -Headers @{ Authorization = "Bearer $accessToken" }
$files = $response.value
$file = $files | Where-Object { $_.name -eq $fileName }
# Get the value of cell B1
$response = Invoke-RestMethod -Method Get -Uri "https://graph.microsoft.com/v1.0/drives/$driveId/items/$fileId/workbook/worksheets/$sheetName/range(address='B1')" -Headers @{ Authorization = "Bearer $accessToken" }
$cellValue = $response.values[0][0]
Write-Output "Current value of B1: $cellValue"
# Update the value of cell B1 to "Changed Value"
# Update the value of cell B1 to "Changed Value"
$updateBody = @{
values = @(
@("Changed Value")
)
}
$response = Invoke-RestMethod -Method Patch -Uri "https://graph.microsoft.com/v1.0/drives/$driveId/items/$fileId/workbook/worksheets/$sheetName/range(address='B1')" -Headers @{ Authorization = "Bearer $accessToken" } -Body ($updateBody | ConvertTo-Json) -ContentType "application/json"
# It return this Error: Invoke-RestMethod : The remote server returned an error: (400) Bad Request.
# Output the response
$response
Consigo acessar o arquivo do Excel Online, a planilha e o valor da célula, mas não consigo escrever um novo valor na célula.
Estou criando um aplicativo de bate-papo em Swift usando URLSession
. Tenho uma solicitação GET autenticada para buscar a lista de amigos do usuário atual. A solicitação funciona perfeitamente no Postman usando o mesmo token e URL, mas meu aplicativo iOS retorna consistentemente um erro 403 com { "detail": "Not Authenticated" }
.
O que eu tentei :
- Garantiu que o cabeçalho de autorização está incluído (
Bearer <token>
) - Registrei a URL completa e o token — eles estão corretos!
- Verifiquei se o servidor de backend está acessível (consigo fazer POST com sucesso)
- Confirmado que a mesma solicitação GET com token funciona bem no Postman
- HTTP inseguro permitido em
Info.plist
(servidor éhttp://52.23.164.179:8000
)
Meu código :
ContactListVC.swift :
private func fetchContacts() {
ContactService.shared.getFriends { [weak self] success, contacts in
guard let self = self else { return }
DispatchQueue.main.async {
if success, let contacts = contacts, !contacts.isEmpty {
self.contacts = contacts
self.tableView.reloadData()
} else {
self.contacts = []
self.showEmptyStateIfNeeded()
}
}
}
}
ContactService.swift :
func getFriends(completion: @escaping (Bool, [ChatPartner]?) -> Void) {
guard let request = contactRequest.getFriends() else {
completion(false, nil)
return
}
NetworkService.shared.sendRequest(request, parse: { data in
guard let json = try? JSONSerialization.jsonObject(with: data) as? [String: Any],
let dataObject = json["data"] as? [String: Any],
let friendsArray = dataObject["friends"] as? [[String: Any]] else {
return nil
}
return friendsArray.compactMap { ChatPartner(json: $0) }
}) { result in
switch result {
case .success(let partners):
completion(true, partners)
case .failure:
completion(false, nil)
}
}
}
ContactRequest.swift :
func getFriends() -> URLRequest? {
guard let baseURL = BASE_URL else { return nil }
let url = baseURL.appendingPathComponent("friends")
var request = URLRequest(url: url)
request.setValue("Bearer \(token ?? "")", forHTTPHeaderField: "Authorization")
request.httpMethod = "GET"
return request
}
Serviço de rede.swift :
func sendRequest<T>(_ request: URLRequest, parse: @escaping (Data) -> T?, completion: @escaping (Result<T, NetworkError>) -> Void) {
let task = URLSession.shared.dataTask(with: request) { data, response, error in
guard let httpResponse = response as? HTTPURLResponse, let data = data else {
completion(.failure(.invalidResponse))
return
}
switch httpResponse.statusCode {
case 200:
if let result = parse(data) {
completion(.success(result))
} else {
completion(.failure(.parsingFailed))
}
default:
completion(.failure(.statusCode(httpResponse.statusCode)))
}
}
task.resume()
}
Info.plist :
<key>NSAppTransportSecurity</key>
<dict>
<key>NSExceptionDomains</key>
<dict>
<key>52.23.164.179</key>
<dict>
<key>NSExceptionAllowsInsecureHTTPLoads</key>
<true/>
<key>NSIncludesSubdomains</key>
<true/>
</dict>
</dict>
<key>NSAllowsArbitraryLoads</key>
<true/>
</dict>
Questões :
- Por que estou recebendo uma resposta 403 no iOS, mas não no Postman com o mesmo token?
- É possível que alguns cabeçalhos ausentes (por exemplo, User-Agent) façam com que a API o rejeite?
Observações extras :
- Confirmei que a solicitação inclui o
Authorization
cabeçalho registrando-o. - Estou usando um endereço IP local (não HTTPS).
- O token não expirou (verificado no Postman).
- Aqui estão algumas imagens quando depuro:
Gostaria de ocultar a interface "next" de um BehaviorSubject, mantendo suas outras propriedades, especialmente a possibilidade de obter o último valor emitido imperativamente. A ideia é que toda manipulação de estado possa ser feita em um BehaviorSubject privado dentro de um serviço, e tudo o que eu exponho é o que eu chamaria de "ReadonlySubject" que não possui o método "next". A única ideia que tenho até agora é algo assim:
export class ReadonlyBehaviorSubject<T> extends BehaviorSubject<T> {
override next(_value: T) {
console.error('cannot set value on a readonly BehaviorSubject');
}
}
export function toReadonlyBehaviorSubject<T>(bs: BehaviorSubject<T>): ReadonlyBehaviorSubject<T> {
return new ReadonlyBehaviorSubject(bs.value);
}
Como você pode ver, ainda temos o método "next" — ele simplesmente não faz nada, apenas informa ao usuário que ele não pode definir um valor em ReadonlyBehaviorSubject. Existe algo mais organizado? De preferência, não expor o método "next" de forma alguma?
Quando crio uma união entre dois tipos de objeto ( A
e B
), espero que uma variável atribuída a esse tipo de união só possa assumir o formato de A
ou B
.
Inesperadamente, bad
não há um erro de tipo aqui, embora intuitivamente devesse haver, pois não satisfaz as restrições de A
nem B
. Link do Typescript Playground
type A = {a: string}
type B = {a: string, b: string, c: string}
type Foo = A | B
// this should be a type error, but it isn't?
// to be valid, it should either:
// - not have "c" property
// - add the "b" property
const bad: Foo = {
a: "",
c: ""
}
Como posso melhorar Foo
para que a bad
variável falhe com um erro de tipo?